经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » SQLite » 查看文章
python 获取sqlite3数据库的表名和表字段名的实例
来源:jb51  时间:2019/7/17 13:11:15  对本文有异议

Python中对sqlite3数据库进行操作时,经常需要用到字段名,然而对于sqlite使用select语句并不能象MySql等数据库一样返回带字段名的字典数据集。特别是对于一个不熟悉的sqlite数据库,写代码时如果需要借助工具查看,那其实是有点对不起python的。

下面两段代码就可以轻易获得一个sqlite数据库中所有数据表名和字段名的列表:

  1. # python 获取sqlite3数据库mydb.db中的表名和表字段名
  2. import sqlite3
  3. conn=sqlite3.connect('mydb.db')
  4. cu=conn.cursor()
  5. #获取表名,保存在tab_name列表
  6. cu.execute("select name from sqlite_master where type='table'")
  7. tab_name=cu.fetchall()
  8. tab_name=[line[0] for line in tab_name]
  9. #获取表的列名(字段名),保存在col_names列表,每个表的字段名集为一个元组
  10. col_names=[]
  11. for line in tab_name:
  12. cu.execute('pragma table_info({})'.format(line))
  13. col_name=cu.fetchall()
  14. col_name=[x[1] for x in col_name]
  15. col_names.append(col_name)
  16. col_name=tuple(col_name)
  17. #之所以保存为元组,一是可避免误操作修改字段名,二是元组巧用转化字符串,可
  18. #直接用于SQL的insert语句中。例如下面代码可得到第一个表的带括号字段名集合:
  19. '''
  20. sql_col_name=str(col_names[0]).replace('\'','')
  21. '''

接下来,用自动获取的字段名做点事吧。

比如,我一个sqlite数据库的表数据是从Excel表中导入的,Excel表中一些误录入的回车符也被一同导入了,在sqlite表中会显示为‘\n'的字符,我想把所有字段中的这个字符都去掉,我是通过以下代码实现的。

  1. #删除第一个表中所有文本型字段中的回车符(注:存入数据库中的回车符取出
  2. #后会展现为原始字符'\n')
  3. cu.execute('select * from '+ tab_name[0])
  4. cdset=cu.fetchall()
  5. cdset=[list(line) for line in cdset] #将结果集的元组转为列表,才能修改。
  6. for line in cdset:
  7. for x in range(len(line)):
  8. #注:作为For循环计数变量不能在循环体中修改,此处不能用x in line代替
  9. if type(line[x])==str and (r'\n' in line[x]): #只能修改字符型数据
  10. line[x]=line[x].replace(r'\n','')
  11. sql="update {bm} set {cm}='{vm}' where {cm2}={vm2}".format(
  12. bm=tab_name[0],cm=col_names[0][x],vm=line[x],cm2=col_names
  13. [0][0],vm2=line[0])
  14. #此处cm2必须是表中具有排它性的主键字段,非字符型字段
  15. cu.execute(sql)
  16. conn.commit()

以上这篇python 获取sqlite3数据库的表名和表字段名的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号