溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

python 獲取sqlite3數(shù)據(jù)庫(kù)的表名和表字段名的實(shí)例

發(fā)布時(shí)間:2020-08-22 20:39:37 來(lái)源:腳本之家 閱讀:525 作者:夢(mèng)游吧 欄目:開(kāi)發(fā)技術(shù)

Python中對(duì)sqlite3數(shù)據(jù)庫(kù)進(jìn)行操作時(shí),經(jīng)常需要用到字段名,然而對(duì)于sqlite使用select語(yǔ)句并不能象MySql等數(shù)據(jù)庫(kù)一樣返回帶字段名的字典數(shù)據(jù)集。特別是對(duì)于一個(gè)不熟悉的sqlite數(shù)據(jù)庫(kù),寫(xiě)代碼時(shí)如果需要借助工具查看,那其實(shí)是有點(diǎn)對(duì)不起python的。

下面兩段代碼就可以輕易獲得一個(gè)sqlite數(shù)據(jù)庫(kù)中所有數(shù)據(jù)表名和字段名的列表:

# python 獲取sqlite3數(shù)據(jù)庫(kù)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列表,每個(gè)表的字段名集為一個(gè)元組
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)
 
#之所以保存為元組,一是可避免誤操作修改字段名,二是元組巧用轉(zhuǎn)化字符串,可
#直接用于SQL的insert語(yǔ)句中。例如下面代碼可得到第一個(gè)表的帶括號(hào)字段名集合:
'''
  sql_col_name=str(col_names[0]).replace('\'','')
'''
 
      

接下來(lái),用自動(dòng)獲取的字段名做點(diǎn)事吧。

比如,我一個(gè)sqlite數(shù)據(jù)庫(kù)的表數(shù)據(jù)是從Excel表中導(dǎo)入的,Excel表中一些誤錄入的回車(chē)符也被一同導(dǎo)入了,在sqlite表中會(huì)顯示為‘\n'的字符,我想把所有字段中的這個(gè)字符都去掉,我是通過(guò)以下代碼實(shí)現(xiàn)的。

#刪除第一個(gè)表中所有文本型字段中的回車(chē)符(注:存入數(shù)據(jù)庫(kù)中的回車(chē)符取出
#后會(huì)展現(xiàn)為原始字符'\n')
cu.execute('select * from '+ tab_name[0])
cdset=cu.fetchall()
cdset=[list(line) for line in cdset] #將結(jié)果集的元組轉(zhuǎn)為列表,才能修改。
for line in cdset:
  for x in range(len(line)):
  #注:作為For循環(huán)計(jì)數(shù)變量不能在循環(huán)體中修改,此處不能用x in line代替
    if type(line[x])==str and (r'\n' in line[x]):  #只能修改字符型數(shù)據(jù)
      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數(shù)據(jù)庫(kù)的表名和表字段名的實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI