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实现可将字符转换成大写的tcp服务器实例
Apr 29 Python
解决pyqt中ui编译成窗体.py中文乱码的问题
Dec 23 Python
Python操作word常见方法示例【win32com与docx模块】
Jul 17 Python
pandas 转换成行列表进行读取与Nan处理的方法
Oct 30 Python
Python实现串口通信(pyserial)过程解析
Sep 25 Python
Django中使用haystack+whoosh实现搜索功能
Oct 08 Python
python安装gdal的两种方法
Oct 29 Python
将python安装信息加入注册表的示例
Nov 20 Python
python爬虫爬取网页数据并解析数据
Sep 18 Python
CocosCreator ScrollView优化系列之分帧加载
Apr 14 Python
Python GUI编程之tkinter 关于 ttkbootstrap 的使用详解
Mar 03 Python
Python使用华为API为图像设置多个锚点标签
Apr 12 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
php访问查询mysql数据的三种方法
2006/10/09 PHP
php学习笔记之面向对象编程
2012/12/29 PHP
PHP使用curl函数发送Post请求的注意事项
2016/11/26 PHP
PHP实现的装箱算法示例
2018/06/23 PHP
PHP5.6读写excel表格文件操作示例
2019/02/26 PHP
javascript 动态添加事件代码
2008/11/30 Javascript
修改jQuery.Autocomplete插件 支持中文输入法 避免TAB、ENTER键失效、导致表单提交
2009/10/11 Javascript
js用Date对象处理时间实现思路及代码
2013/01/31 Javascript
JS特殊函数(Function()构造函数、函数直接量)区别介绍
2013/05/19 Javascript
引入JS文件IE6报语法错误或缺少对象问题的解决方法
2014/01/09 Javascript
浅谈JavaScript字符集
2014/05/22 Javascript
javascript实现可键盘控制的抽奖系统
2016/03/10 Javascript
Vue.JS入门教程之处理表单
2016/12/01 Javascript
JQuery 动态生成Table表格实例代码
2016/12/02 Javascript
H5上传本地图片并预览功能
2017/05/08 Javascript
微信小程序实现皮肤功能(夜间模式)
2017/06/18 Javascript
jQuery获取table表中的td标签(实例讲解)
2017/07/28 jQuery
Javascript中的getter和setter初识
2017/08/17 Javascript
使用原生js封装的ajax实例(兼容jsonp)
2017/10/12 Javascript
JavaScript隐式类型转换代码实例
2020/05/29 Javascript
Vue组件为什么data必须是一个函数
2020/06/11 Javascript
Python读写Excel文件的实例
2013/11/01 Python
pymssql数据库操作MSSQL2005实例分析
2015/05/25 Python
Python自动化测试ConfigParser模块读写配置文件
2016/08/15 Python
Python实现统计代码行的方法分析
2017/07/12 Python
python编写暴力破解zip文档程序的实例讲解
2018/04/24 Python
解析python的局部变量和全局变量
2019/08/15 Python
利用python下载scihub成文献为PDF操作
2020/07/09 Python
appium+python自动化配置(adk、jdk、node.js)
2020/11/17 Python
Beach Bunny Swimwear官网:设计师泳装和性感比基尼
2019/03/13 全球购物
一套Delphi的笔试题一
2016/02/14 面试题
医学专业毕业生个人求职信
2013/12/25 职场文书
保险专业大学生职业规划书
2014/03/03 职场文书
女生抽烟检讨书
2014/10/05 职场文书
后勤个人工作总结
2015/02/28 职场文书
2015年社区重阳节活动总结
2015/07/30 职场文书