gpt4 book ai didi

Python sqlite3 : how to insert data with missing key/value?

转载 作者:太空宇宙 更新时间:2023-11-04 05:16:51 25 4
gpt4 key购买 nike

我想使用 sqlite3 将 json 格式的新数据条目添加到数据库中。示例数据库“test.db”有一个表“cars”,它有 3 个值,“MAKE”、“MODEL”和“COST”。新数据包含缺少名称/值对的条目:

entries = {
"CARS":[
{
"MAKE": "VW",
"MODEL":"Passat",
"COST":23000
},
{
"MAKE":"Honda",
"MODEL":"Civic"
}
]
}

为了避免引发 KeyError,我使用了 setdefault() 并添加了 key/None 对(如果它们在每个条目中都缺失):

import sqlite3

keys = ["MAKE", "MODEL", "COST"]
with sqlite3.connect("test.db") as conn:
c = conn.cursor()

for car in entries['CARS']:
for key in keys:
car.setdefault(key, None)
c.execute('INSERT INTO cars VALUES(?,?,?)', (car['MAKE'], car['MODEL'], car['COST']))

虽然这似乎可行,但是否还有一种方法可以使用 SQL 语法添加缺少名称/值对的条目?

最佳答案

当您使用参数绑定(bind)时,您必须提供与字符串中的参数一样多的参数。这不是 SQL 语法的问题,而是参数绑定(bind)语法的问题。我看不出有任何解决办法。

您可以结合使用 collections.defaultdict()named 参数绑定(bind)来使代码更具可读性:

import sqlite3
from collections import defaultdict

keys = ["MAKE", "MODEL", "COST"]
with sqlite3.connect(":memory:") as conn:
c = conn.cursor()
c.execute("create table cars (make, model, cost)")

for car in entries['CARS']:
car = defaultdict(lambda: None, car)
c.execute('INSERT INTO cars VALUES(:MAKE,:MODEL,:COST)', car)

关于Python sqlite3 : how to insert data with missing key/value?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41491800/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com