当前位置:  开发笔记 > 编程语言 > 正文

使用Python参数替换将记录插入到Sqlite中,其中某些字段为空

如何解决《使用Python参数替换将记录插入到Sqlite中,其中某些字段为空》经验,为你挑选了1个好方法。

我正在运行这种查询:

insert into mytable (id, col1, col2)
values (:ID, :COL1, :COL2)

在Python中,此表单的字典可以与上面的查询结合使用以进行参数替换:

d = { 'ID' : 0, 'COL1' : 'hi', 'COL2' : 'there' }
cursor.execute(sql_insert, d)

但在真正的问题中,有很多列和很多行.有时,填充字典的数据源没有条目.但是,如果字典很短,Sqlite会抱怨提供的绑定数量不正确,而不是给我一种方法在这种情况下未填充的列中添加空字符串或NULL.

我是一个懒惰的人,或者是一个完美主义者.我可以编写一些代码来将任何缺少的字段添加到字典中.我只是在寻找一种优雅的解决方案,不需要将字段列表重复三次.

我尝试使用修改后的字典重载字典,如果字段丢失,则返回空字符串.



1> Duncan..:

我没有检查过这是否有效,但我认为它应该:

from collections import defaultdict
d = { 'ID' : 0, 'COL1' : 'hi' }
cursor.execute(sql_insert, defaultdict(str, d))

defaultdict是一个专门的字典,其中任何缺少的键生成一个新值而不是抛出一个KeyError.

当然,只有当所有值都需要相同的默认值(例如空字符串或None)时,这才有效.如果你需要不同的默认值,那么你需要一个包含默认值的字典,你可以这样做:

DEFAULTS = { ... whatever ... }
d = { 'ID' : 0, 'COL1' : 'hi' }
cursor.execute(sql_insert, dict(DEFAULTS).update(d))

请注意,每次都必须复制DEFAULTS,以便可以使用实际值更新副本.

推荐阅读
Chloemw
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有