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 获取 Linux 系统信息的代码
Jul 13 Python
编程语言Python的发展史
Sep 26 Python
python计算对角线有理函数插值的方法
May 07 Python
python修改操作系统时间的方法
May 18 Python
Python实现的使用telnet登陆聊天室实例
Jun 17 Python
python查看zip包中文件及大小的方法
Jul 09 Python
使用 Python 处理 JSON 格式的数据
Jul 22 Python
python的scipy实现插值的示例代码
Nov 12 Python
Python数据分析入门之数据读取与存储
May 13 Python
对PyTorch中inplace字段的全面理解
May 22 Python
python文本处理的方案(结巴分词并去除符号)
May 26 Python
python井字棋游戏实现人机对战
Apr 28 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
很实用的一个完整email发送程序
2006/10/09 PHP
php面向对象全攻略 (六)__set() __get() __isset() __unset()的用法
2009/09/30 PHP
PHP命名空间(Namespace)简明教程
2014/06/11 PHP
php计算两个日期时间差(返回年、月、日)
2014/06/19 PHP
php传值方式和ajax的验证功能
2017/03/27 PHP
php删除二维数组中的重复值方法
2018/03/12 PHP
Laravel5框架自定义错误页面配置操作示例
2019/04/17 PHP
js实现屏蔽默认快捷键调用自定义事件示例
2013/06/18 Javascript
JS实现鼠标单击与双击事件共存
2014/03/08 Javascript
JavaScript的面向对象编程基础
2015/08/13 Javascript
jQuery插件datatables使用教程
2016/04/21 Javascript
JQueryMiniUI按照时间进行查询的实现方法
2017/06/07 jQuery
React Native 图片查看组件的方法
2018/03/01 Javascript
json 带斜杠时如何解析的实现
2019/08/12 Javascript
详解Nuxt.js中使用Element-UI填坑
2019/09/06 Javascript
微信小程序如何通过用户授权获取手机号(getPhoneNumber)
2020/01/21 Javascript
微信小程序轮播图swiper代码详解
2020/12/01 Javascript
Python调用SQLPlus来操作和解析Oracle数据库的方法
2016/04/09 Python
Windows下Python使用Pandas模块操作Excel文件的教程
2016/05/31 Python
python使用pymysql实现操作mysql
2016/09/13 Python
浅谈python中requests模块导入的问题
2018/05/18 Python
Python日期时间Time模块实例详解
2019/04/15 Python
python实现图像拼接功能
2020/03/23 Python
Python使用monkey.patch_all()解决协程阻塞问题
2020/04/15 Python
俄罗斯小米家用电器、电子产品和智能家居商店:Poood.ru
2020/04/03 全球购物
梅西百货官网:Macy’s
2020/08/04 全球购物
环境工程大学生个人的自我评价
2013/10/08 职场文书
机电专业毕业生求职信
2013/10/27 职场文书
现金出纳岗位职责
2014/03/15 职场文书
经营目标管理责任书
2014/07/25 职场文书
项目合作意向书模板
2014/07/29 职场文书
2014年党员自我评议总结
2014/09/23 职场文书
教师学习三严三实心得体会
2014/10/13 职场文书
幼儿园感谢信
2015/01/21 职场文书
大学生入党群众意见书
2015/06/02 职场文书
Python OpenCV超详细讲解读取图像视频和网络摄像头
2022/04/02 Python