python 獲取sqlite3數(shù)據(jù)庫(kù)的表名和表字段名的實(shí)例
Python中對(duì)sqlite3數(shù)據(jù)庫(kù)進(jìn)行操作時(shí),經(jīng)常需要用到字段名,然而對(duì)于sqlite使用select語句并不能象MySql等數(shù)據(jù)庫(kù)一樣返回帶字段名的字典數(shù)據(jù)集。特別是對(duì)于一個(gè)不熟悉的sqlite數(shù)據(jù)庫(kù),寫代碼時(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語句中。例如下面代碼可得到第一個(gè)表的帶括號(hào)字段名集合:
'''
sql_col_name=str(col_names[0]).replace('\'','')
'''
接下來,用自動(dòng)獲取的字段名做點(diǎn)事吧。
比如,我一個(gè)sqlite數(shù)據(jù)庫(kù)的表數(shù)據(jù)是從Excel表中導(dǎo)入的,Excel表中一些誤錄入的回車符也被一同導(dǎo)入了,在sqlite表中會(huì)顯示為‘\n'的字符,我想把所有字段中的這個(gè)字符都去掉,我是通過以下代碼實(shí)現(xiàn)的。
#刪除第一個(gè)表中所有文本型字段中的回車符(注:存入數(shù)據(jù)庫(kù)中的回車符取出
#后會(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è)參考,也希望大家多多支持腳本之家。
相關(guān)文章
通過selenium抓取某東的TT購(gòu)買記錄并分析趨勢(shì)過程解析
這篇文章主要介紹了通過selenium抓取某東的TT購(gòu)買記錄并分析趨勢(shì)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08
Python?matplotlib包和gif包生成gif動(dòng)畫實(shí)戰(zhàn)對(duì)比
使用matplotlib生成gif動(dòng)畫的方法相信大家應(yīng)該都看到過,下面這篇文章主要給大家介紹了關(guān)于Python?matplotlib包和gif包生成gif動(dòng)畫對(duì)比的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05
Python實(shí)現(xiàn)字典依據(jù)value排序
新華字典大家都使用過吧,那么使用python語言是如何實(shí)現(xiàn)字典排序的呢?下面跟著本教程一起學(xué)習(xí)Python實(shí)現(xiàn)字典依據(jù)value排序,需要的朋友參考下吧2016-02-02
解決Python安裝時(shí)報(bào)缺少DLL問題【兩種解決方法】
這篇文章主要介紹了解決Python安裝時(shí)報(bào)缺少DLL問題,本文通過兩種方法給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-07-07
Pandas使用分隔符或正則表達(dá)式將字符串拆分為多列
本文主要介紹了Pandas使用分隔符或正則表達(dá)式將字符串拆分為多列,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02
python 非線性規(guī)劃方式(scipy.optimize.minimize)
今天小編就為大家分享一篇python 非線性規(guī)劃方式(scipy.optimize.minimize),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-02-02
python的numpy模塊安裝不成功簡(jiǎn)單解決方法總結(jié)
這篇文章主要介紹了python的numpy模塊安裝不成功簡(jiǎn)單解決方法總結(jié),分享了四種python模塊導(dǎo)入不成功的解決方法,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12
基于python調(diào)用jenkins-cli實(shí)現(xiàn)快速發(fā)布
這篇文章主要介紹了基于python調(diào)用jenkins-cli實(shí)現(xiàn)快速發(fā)布,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08
Python自動(dòng)化之?dāng)?shù)據(jù)驅(qū)動(dòng)讓你的腳本簡(jiǎn)潔10倍【推薦】
數(shù)據(jù)驅(qū)動(dòng)是一種思想,讓數(shù)據(jù)和代碼進(jìn)行分離。這篇文章主要介紹了Python自動(dòng)化之?dāng)?shù)據(jù)驅(qū)動(dòng),讓你的腳本簡(jiǎn)潔10倍,需要的朋友可以參考下2019-06-06

