python 获取sqlite3数据库的表名和表字段名的实例


Posted in Python onJuly 17, 2019

Python中对sqlite3数据库进行操作时,经常需要用到字段名,然而对于sqlite使用select语句并不能象MySql等数据库一样返回带字段名的字典数据集。特别是对于一个不熟悉的sqlite数据库,写代码时如果需要借助工具查看,那其实是有点对不起python的。

下面两段代码就可以轻易获得一个sqlite数据库中所有数据表名和字段名的列表:

# python 获取sqlite3数据库mydb.db中的表名和表字段名
 
import sqlite3
conn=sqlite3.connect('mydb.db')
cu=conn.cursor()
 
#获取表名,保存在tab_name列表
cu.execute("select name from sqlite_master where type='table'")
tab_name=cu.fetchall()
tab_name=[line[0] for line in tab_name]
 
#获取表的列名(字段名),保存在col_names列表,每个表的字段名集为一个元组
col_names=[]
for line in tab_name:
  cu.execute('pragma table_info({})'.format(line))
  col_name=cu.fetchall()
  col_name=[x[1] for x in col_name]
  col_names.append(col_name)
  col_name=tuple(col_name)
 
#之所以保存为元组,一是可避免误操作修改字段名,二是元组巧用转化字符串,可
#直接用于SQL的insert语句中。例如下面代码可得到第一个表的带括号字段名集合:
'''
  sql_col_name=str(col_names[0]).replace('\'','')
'''

接下来,用自动获取的字段名做点事吧。

比如,我一个sqlite数据库的表数据是从Excel表中导入的,Excel表中一些误录入的回车符也被一同导入了,在sqlite表中会显示为‘\n'的字符,我想把所有字段中的这个字符都去掉,我是通过以下代码实现的。

#删除第一个表中所有文本型字段中的回车符(注:存入数据库中的回车符取出
#后会展现为原始字符'\n')
cu.execute('select * from '+ tab_name[0])
cdset=cu.fetchall()
cdset=[list(line) for line in cdset] #将结果集的元组转为列表,才能修改。
for line in cdset:
  for x in range(len(line)):
  #注:作为For循环计数变量不能在循环体中修改,此处不能用x in line代替
    if type(line[x])==str and (r'\n' in line[x]):  #只能修改字符型数据
      line[x]=line[x].replace(r'\n','')
      sql="update {bm} set {cm}='{vm}' where {cm2}={vm2}".format(
        bm=tab_name[0],cm=col_names[0][x],vm=line[x],cm2=col_names
        [0][0],vm2=line[0])
        #此处cm2必须是表中具有排它性的主键字段,非字符型字段
      cu.execute(sql)
conn.commit()

以上这篇python 获取sqlite3数据库的表名和表字段名的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python网络编程之UDP通信实例(含服务器端、客户端、UDP广播例子)
Apr 25 Python
Python实现简单的多任务mysql转xml的方法
Feb 08 Python
django admin添加数据自动记录user到表中的实现方法
Jan 05 Python
python书籍信息爬虫实例
Mar 19 Python
python2.7实现FTP文件下载功能
Apr 15 Python
python实现计数排序与桶排序实例代码
Mar 28 Python
使用Python Pandas处理亿级数据的方法
Jun 24 Python
python3.7 的新特性详解
Jul 25 Python
Python中实现输入一个整数的案例
May 03 Python
Python OpenCV读取中文路径图像的方法
Jul 02 Python
python实现批处理文件
Jul 28 Python
python中 .npy文件的读写操作实例
Apr 14 Python
Python math库 ln(x)运算的实现及原理
Jul 17 #Python
Python_查看sqlite3表结构,查询语句的示例代码
Jul 17 #Python
10分钟用python搭建一个超好用的CMDB系统
Jul 17 #Python
在SQLite-Python中实现返回、查询中文字段的方法
Jul 17 #Python
PIL图像处理模块paste方法简单使用详解
Jul 17 #Python
python 实现GUI(图形用户界面)编程详解
Jul 17 #Python
解决python tkinter界面卡死的问题
Jul 17 #Python
You might like
如何取得中文输入的真实长度?
2006/06/24 Javascript
AngularJS入门教程(二):AngularJS模板
2014/12/06 Javascript
JavaScript类继承及实例化的方法
2015/07/25 Javascript
JavaScript获取各大浏览器信息图示
2015/11/20 Javascript
jquery淡入淡出效果简单实例
2016/01/14 Javascript
jQuery操作dom实现弹出页面遮罩层(web端和移动端阻止遮罩层的滑动)
2016/08/25 Javascript
Bootstrap基本样式学习笔记之图片(6)
2016/12/07 Javascript
js实现可以点击收缩或张开的悬浮窗
2017/09/18 Javascript
详解Vuex管理登录状态
2017/11/13 Javascript
5 种JavaScript编码规范
2018/01/30 Javascript
微信小程序实践之动态控制组件的显示/隐藏功能
2018/07/18 Javascript
jQuery 获取除某指定对象外的其他对象 ( :not() 与.not())
2018/10/10 jQuery
[45:15]Optic vs VP 2018国际邀请赛淘汰赛BO3 第一场 8.24
2018/08/25 DOTA
python和bash统计CPU利用率的方法
2015/07/10 Python
深度定制Python的Flask框架开发环境的一些技巧总结
2016/07/12 Python
Python pymongo模块用法示例
2018/03/31 Python
对python函数签名的方法详解
2019/01/22 Python
Python3.5面向对象与继承图文实例详解
2019/04/24 Python
Django框架登录加上验证码校验实现验证功能示例
2019/05/23 Python
wxpython实现按钮切换界面的方法
2019/11/19 Python
使用 Python 清理收藏夹里已失效的网站
2019/12/03 Python
pytorch获取模型某一层参数名及参数值方式
2019/12/30 Python
CAT鞋美国官网:CAT Footwear
2017/11/27 全球购物
NBA德国官方网上商店:NBA Store德国
2018/04/13 全球购物
管理学专业个人求职信范文
2013/09/21 职场文书
在求职信中如何凸显个人优势
2013/10/30 职场文书
高中班长自我鉴定
2013/12/20 职场文书
运动会解说词200字
2014/02/06 职场文书
税务会计岗位职责
2014/02/18 职场文书
团日活动总结模板
2014/06/25 职场文书
公务员学习习总书记“三严三实”思想汇报
2014/09/19 职场文书
违章停车检讨书
2014/10/21 职场文书
亮剑观后感600字
2015/06/05 职场文书
2019交通安全宣传标语集锦!
2019/06/28 职场文书
python爬虫框架feapde的使用简介
2021/04/20 Python
python和anaconda的区别
2022/05/06 Python