首页 > 数据库 > mysql教程 > 如何从 SQLite 查询中检索字典而不是列表?

如何从 SQLite 查询中检索字典而不是列表?

Susan Sarandon
发布: 2025-01-03 20:33:40
原创
149 人浏览过

How Can I Retrieve Dictionaries Instead of Lists from SQLite Queries?

从 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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板