python获取sqlite3数据库的表名和表字段名的实例

  

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

  

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

        # python获取sqlite3数据库mydb.db中的表名和表字段名      进口sqlite3   康涅狄格州=sqlite3.connect (“mydb.db”)   铜=conn.cursor ()      #获取表名,保存在tab_name列表   铜。执行(“选择名称从sqlite_master类型=表”)   tab_name=cu.fetchall ()   tab_name=[[0]为线tab_name)      #获取表的列名(字段名),保存在col_names列表,每个表的字段名集为一个元组   col_names=[]   在tab_name线:   铜。执行(“杂注table_info ({}) .format(线))   col_name=cu.fetchall ()   col_name=[x [1] x col_name)   col_names.append (col_name)   col_name=元组(col_name)      #之所以保存为元组,一是可避免误操作修改字段名,二是元组巧用转化字符串,可   #直接用于SQL的插入语句中,例如下面代码可得到第一个表的带括号字段名集合:   “‘   sql_col_name=str (col_names [0]) .replace (“\”、“)   “‘         之前      

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

  

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

        #删除第一个表中所有文本型字段中的回车符(注:存入数据库中的回车符取出   #后会展现为原始字符“\ n”)   铜。执行(“select * from”+ tab_name [0])   cdset=cu.fetchall ()   cdset=[列表(线)在cdset] #将结果集的元组转为列的表,才能修改。   在cdset线:   x的范围(len()行):   #注:作为为循环计数变量不能在循环体中修改,此处不能用x线代替   如果类型([x])行==str和(r ' \ n '一致[x]): #只能修改字符型数据   线[x]=[x] .replace (r ' \ n ',”)   sql="更新组{黑}{厘米}=' {vm}, {cm2}={vm2} " .format (   bm=tab_name[0]厘米=col_names [0] [x], vm=[x], cm2=col_names   [0][0],vm2=[0]行)   #此处cm2必须是表中具有排它性的主键字段,非字符型字段   cu.execute (sql)   conn.commit ()   之前      

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

python获取sqlite3数据库的表名和表字段名的实例