从 SQLite 查询中检索字典
从 SQLite 数据库检索数据通常会生成一个列表列表,其中每个内部列表对应一个数据库中的行。虽然此方法很实用,但通过列名访问数据可能不方便。本文探讨了从 SQLite 查询获取字典的替代方法,提供了一种更直观的数据处理方式。
Row Factory
row_factory 函数允许您指定如何返回结果行。通过设置为dict_factory,可以将查询结果转换为字典,其中key为列名,value为列值。下面是一个示例:
import sqlite3 def dict_factory(cursor, row): d = {} for idx, col in enumerate(cursor.description): d[col[0]] = row[idx] return d con = sqlite3.connect(":memory:") con.row_factory = dict_factory cur = con.cursor() cur.execute("select 1 as a") print(cur.fetchone()["a"])
SQLite3.Row
另一个选项是使用 sqlite3.Row 类型作为行工厂。它以最小的内存开销提供基于索引和不区分大小写的基于名称的列访问:
con = sqlite3.connect(...) con.row_factory = sqlite3.Row # add this row cursor = con.cursor()
使用 sqlite3.Row,您可以通过索引或名称访问列值:
row = cursor.fetchone() value_by_index = row[0] value_by_name = row["col_name"]
结论
row_factory 函数和sqlite3.Row 类型提供了从 SQLite 查询中检索字典的有效方法,使得按列名称处理数据变得更容易。两者之间的选择取决于具体要求和偏好。
以上是如何从 SQLite 查询中检索字典而不是列表?的详细内容。更多信息请关注PHP中文网其他相关文章!