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文件操作类操作实例详解
Jul 11 Python
Win7下搭建python开发环境图文教程(安装Python、pip、解释器)
May 17 Python
使用Python的Scrapy框架十分钟爬取美女图
Dec 26 Python
使用pyecharts在jupyter notebook上绘图
Apr 23 Python
名片管理系统python版
Jan 11 Python
浅谈Python中重载isinstance继承关系的问题
May 04 Python
python opencv实现旋转矩形框裁减功能
Jul 25 Python
pyqt5 QScrollArea设置在自定义侧(任何位置)
Sep 25 Python
Python手动或自动协程操作方法解析
Jun 22 Python
Python读写锁实现实现代码解析
Nov 28 Python
pycharm进入时每次都是insert模式的解决方式
Feb 05 Python
python 利用panda 实现列联表(交叉表)
Feb 06 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 JSON 数据解析代码
2010/05/26 PHP
PHP中魔术变量__METHOD__与__FUNCTION__的区别
2014/09/29 PHP
Symfony模板的快捷变量用法实例
2016/03/17 PHP
利用laravel搭建一个迷你博客实战教程
2017/08/13 PHP
javascript引用对象的方法代码
2007/08/13 Javascript
12行javascript代码绘制一个八卦图
2015/04/02 Javascript
jquery+php随机生成红包金额数量代码分享
2015/08/27 Javascript
JavaScript实现带缓冲效果的随屏滚动漂浮广告代码
2015/11/06 Javascript
EasyUI 结合JS导出Excel文件的实现方法
2016/11/10 Javascript
基于jPlayer三分屏的制作方法
2016/12/21 Javascript
解决html input验证只能输入数字,不能输入其他的问题
2017/07/21 Javascript
BootStrap给table表格的每一行添加一个按钮事件
2017/09/07 Javascript
使用live-server快速搭建本地服务器+自动刷新的方法
2018/03/09 Javascript
React Router v4 入坑指南(小结)
2018/04/08 Javascript
JavaScript生成指定范围随机数和随机序列的方法
2018/05/05 Javascript
vue3.0 CLI - 1 - npm 安装与初始化的入门教程
2018/09/14 Javascript
解决layui的使用以及针对select、radio等表单组件不显示的问题
2019/09/05 Javascript
你知道JavaScript Symbol类型怎么用吗
2020/01/08 Javascript
jquery将信息遍历到界面上实例代码
2020/01/21 jQuery
JS获取表格视图所选行号的ids过程解析
2020/02/21 Javascript
小程序角标的添加及绑定购物车数量进行实时更新的实现代码
2020/12/07 Javascript
Python脚本实现自动发带图的微博
2016/04/27 Python
python中关于for循环的碎碎念
2017/06/30 Python
wx.CheckBox创建复选框控件并响应鼠标点击事件
2018/04/25 Python
Flask入门之上传文件到服务器的方法示例
2018/07/18 Python
基于PyQt4和PySide实现输入对话框效果
2019/02/27 Python
波比布朗英国官网:Bobbi Brown英国
2017/11/13 全球购物
Roxy俄罗斯官方网站:冲浪和滑雪板的一切
2020/06/20 全球购物
八一演出活动方案
2014/02/03 职场文书
餐厅经理岗位职责范本
2014/02/17 职场文书
2014年高考决心书
2014/03/11 职场文书
农民工讨薪标语
2014/06/26 职场文书
先进个人评语大全
2015/01/04 职场文书
自我检讨书范文
2015/01/28 职场文书
武侯祠导游词
2015/02/04 职场文书
Java数据开发辅助工具Docker与普通程序使用方法
2021/09/15 Java/Android