本文實例講述了Python實現Sqlite將字段當做索引進行查詢的方法。分享給大家供大家參考,具體如下:
默認從sqlite中獲取到的數據是數字索引的, 在開發階段經常有修改數據庫所以顯得不太方便, 其實在python源碼里就有解決方案, 直接讀sqlite3的源碼, 摸索了一些, 解決方案如下:
默認連接的話使用一下代碼是以數字為索引的:
conn = sqlite3.connect(dbfile)cur = conn.cursor()
為了使得獲取到的結果集以字段為索引, 需要添加一個函數和一個類:
def dict_factory(cursor, row): d = {} for idx, col in enumerate(cursor.description): d[col[0]] = row[idx] return dclass 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)
之后讀取出來的便是以字段為索引的了.
更多關于Python相關內容感興趣的讀者可查看本站專題:《Python常見數據庫操作技巧匯總》、《Python數據結構與算法教程》、《Python Socket編程技巧總結》、《Python函數使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設計有所幫助。
新聞熱點
疑難解答
圖片精選