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 list语法学习(带例子)
Nov 01 Python
Python中实现字符串类型与字典类型相互转换的方法
Aug 18 Python
win7上python2.7连接mysql数据库的方法
Jan 14 Python
Python实现自动上京东抢手机
Feb 06 Python
Python MySQLdb 使用utf-8 编码插入中文数据问题
Mar 13 Python
Python面向对象类编写细节分析【类,方法,继承,超类,接口等】
Jan 05 Python
Python数据类型之列表和元组的方法实例详解
Jul 08 Python
python属于解释型语言么
Jun 15 Python
python opencv实现简易画图板
Aug 27 Python
python爬虫中采集中遇到的问题整理
Nov 27 Python
Python+MySQL随机试卷及答案生成程序的示例代码
Feb 01 Python
pytorch查看网络参数显存占用量等操作
May 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
Session的工作方式
2006/10/09 PHP
实例(Smarty+FCKeditor新闻系统)
2007/01/02 PHP
phpMyadmin 用户权限中英对照
2010/04/02 PHP
IIS下PHP连接数据库提示mysql undefined function mysql_connect()
2010/06/04 PHP
简单的php缓存类分享     php缓存机制
2014/01/22 PHP
PHP实现图片不变型裁剪及图片按比例裁剪的方法
2016/01/14 PHP
ext读取两种结构的xml的代码
2008/11/05 Javascript
Javascript中Eval函数的使用
2010/03/23 Javascript
用js实现的模拟jquery的animate自定义动画(2.5K)
2010/07/20 Javascript
js调用AJAX时Get和post的乱码解决方法
2013/06/04 Javascript
JS onmousemove鼠标移动坐标接龙DIV效果实例
2013/12/16 Javascript
Jquery 分页插件之Jquery Pagination
2015/08/25 Javascript
jQuery+CSS实现滑动的标签分栏切换效果
2015/12/17 Javascript
单击按钮发送验证码,出现倒计时的简单实例
2017/03/17 Javascript
ES6学习教程之对象字面量详解
2017/10/09 Javascript
vue vue-Router默认hash模式修改为history需要做的修改详解
2018/09/13 Javascript
D3.js的基础部分之数组的处理数组的排序和求值(v3版本)
2019/05/09 Javascript
JavaScript获取当前url路径过程解析
2019/12/27 Javascript
es6函数之rest参数用法实例分析
2020/04/18 Javascript
[42:22]DOTA2上海特级锦标赛C组小组赛#1 OG VS Archon第一局
2016/02/27 DOTA
[08:38]DOTA2-DPC中国联赛 正赛 VG vs Elephant 选手采访
2021/03/11 DOTA
Django权限机制实现代码详解
2018/02/05 Python
详解用Python实现自动化监控远程服务器
2019/05/18 Python
Python学习笔记之读取文件、OS模块、异常处理、with as语法示例
2019/06/04 Python
通过python改变图片特定区域的颜色详解
2019/07/15 Python
django 微信网页授权登陆的实现
2019/07/30 Python
Python 从subprocess运行的子进程中实时获取输出的例子
2019/08/14 Python
python 线性回归分析模型检验标准--拟合优度详解
2020/02/24 Python
jupyter notebook参数化运行python方式
2020/04/10 Python
使用html5+css3来实现slider切换效果告别javascript+css
2013/01/08 HTML / CSS
三陽商会官方网站:Sanyo iStore
2019/05/15 全球购物
2014年高中班主任工作总结
2014/11/08 职场文书
出纳试用期自我评价
2015/03/10 职场文书
2015年农村党员干部主题教育活动总结
2015/03/25 职场文书
《山中访友》教学反思
2016/02/24 职场文书
全网非常详细的pytest配置文件
2022/07/15 Python