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的即时标记项目练习笔记
Sep 18 Python
python使用装饰器和线程限制函数执行时间的方法
Apr 18 Python
Python制作简易注册登录系统
Dec 15 Python
Python使用一行代码获取上个月是几月
Aug 30 Python
python去除拼音声调字母,替换为字母的方法
Nov 28 Python
Python 实现中值滤波、均值滤波的方法
Jan 09 Python
Python3中lambda表达式与函数式编程讲解
Jan 14 Python
Python中类的创建和实例化操作示例
Feb 27 Python
PythonWeb项目Django部署在Ubuntu18.04腾讯云主机上
Apr 01 Python
利用keras加载训练好的.H5文件,并实现预测图片
Jan 24 Python
python ImageDraw类实现几何图形的绘制与文字的绘制
Feb 26 Python
python GUI库图形界面开发之PyQt5工具栏控件QToolBar的详细使用方法与实例
Feb 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
php代码优化及php相关问题总结
2006/10/09 PHP
wamp下修改mysql访问密码的解决方法
2013/05/07 PHP
浅析PHP原理之变量分离/引用(Variables Separation)
2013/08/09 PHP
php获取excel文件数据
2017/04/21 PHP
laravel5.1 ajax post 传值_token示例
2019/10/24 PHP
javascript showModalDialog模态对话框使用说明
2009/12/31 Javascript
如何用JavaScript动态呼叫函数(两种方式)
2013/05/03 Javascript
jquery ajax post提交数据乱码
2013/11/05 Javascript
javascript去除空格方法小结
2015/05/21 Javascript
动态加载css方法实现和深入解析
2017/01/18 Javascript
AngularJS使用angular.bootstrap完成模块手动加载的方法分析
2017/01/19 Javascript
使用jQuery实现两个div中按钮互换位置的实例代码
2017/09/21 jQuery
jquery一键控制checkbox全选、反选或全不选
2017/10/16 jQuery
AJAX在JQuery中的应用详解
2019/01/30 jQuery
微信小程序批量上传图片到七牛(推荐)
2019/12/19 Javascript
JS对象属性的检测与获取操作实例分析
2020/03/17 Javascript
jQuery实现开关灯效果
2020/08/02 jQuery
五句话帮你轻松搞定js原型链
2020/12/09 Javascript
React服务端渲染原理解析与实践
2021/03/04 Javascript
详解Python中的type()方法的使用
2015/05/21 Python
python3中set(集合)的语法总结分享
2017/03/24 Python
Python自动化开发学习之三级菜单制作
2017/07/14 Python
Python比较配置文件的方法实例详解
2019/06/06 Python
python处理excel绘制雷达图
2019/10/18 Python
Python利用 utf-8-sig 编码格式解决写入 csv 文件乱码问题
2020/02/21 Python
使用Matplotlib绘制不同颜色的带箭头的线实例
2020/04/17 Python
澳大利亚领先的美容护肤品零售商之一:SkincareStore
2018/01/22 全球购物
Hotels.com加拿大:领先的在线住宿网站
2018/10/05 全球购物
Internet体系结构
2014/12/21 面试题
PHP使用Redis队列执行定时任务实例讲解
2021/03/24 PHP
销售员个人求职的自我评价
2014/02/10 职场文书
环保倡议书范文
2014/05/12 职场文书
学校食品安全责任书
2015/01/29 职场文书
幼儿园百日安全活动总结
2015/05/07 职场文书
2015年度环卫处工作总结
2015/07/24 职场文书
自从在 IDEA 中用了热部署神器 JRebel 之后,开发效率提升了 10(真棒)
2021/06/26 Java/Android