abstract:本文實(shí)例講述了Python實(shí)現(xiàn)Sqlite將字段當(dāng)做索引進(jìn)行查詢的方法。分享給大家供大家參考,具體如下:默認(rèn)從sqlite中獲取到的數(shù)據(jù)是數(shù)字索引的, 在開發(fā)階段經(jīng)常有修改數(shù)據(jù)庫所以顯得不太方便, 其實(shí)在python源碼里就有解決方案, 直接讀sqlite3的源碼, 摸索了一些, 解決方案如下:默認(rèn)連接的話使用一下代碼是以數(shù)字為索引的:conn = sqlite3.connec
本文實(shí)例講述了Python實(shí)現(xiàn)Sqlite將字段當(dāng)做索引進(jìn)行查詢的方法。分享給大家供大家參考,具體如下:
默認(rèn)從sqlite中獲取到的數(shù)據(jù)是數(shù)字索引的, 在開發(fā)階段經(jīng)常有修改數(shù)據(jù)庫所以顯得不太方便, 其實(shí)在python源碼里就有解決方案, 直接讀sqlite3的源碼, 摸索了一些, 解決方案如下:
默認(rèn)連接的話使用一下代碼是以數(shù)字為索引的:
conn = sqlite3.connect(dbfile) cur = conn.cursor()
為了使得獲取到的結(jié)果集以字段為索引, 需要添加一個(gè)函數(shù)和一個(gè)類:
def dict_factory(cursor, row): d = {} for idx, col in enumerate(cursor.description): d[col[0]] = row[idx] return d class MyCursor(sqlite3.Cursor): def __init__(self, *args, **kwargs): sqlite3.Cursor.__init__(self, *args, **kwargs) self.row_factory = dict_factory
然后修改連接的代碼:
conn = sqlite3.connect(dbfile) cur = conn.cursor(factory=MyCursor)
之后讀取出來的便是以字段為索引的了.
更多關(guān)于Python實(shí)現(xiàn)Sqlite將字段當(dāng)做索引進(jìn)行查詢的方法請(qǐng)關(guān)注PHP中文網(wǎng)(www.miracleart.cn)其他文章!