我的脚本解析 JSON 文件的目录并在数据库中为每个文件创建表。我现在正在从这些文件中导入数据。为了构建具有可变长度列数的 SQL 查询字符串,我需要在查询字符串的每一列附加 %s,然后用“)”关闭查询字符串,并将其返回到导入记录函数。
工作代码如下所示:
TABLES[tablename] += (
"INSERT INTO " + tablename + str(tuple(table[0].keys())).replace("'", "")
)
TABLES[tablename] += "\nVALUES\n("
然后是有问题的部分:
for key in table[0].keys():
key = key # just to shut the linter up...
TABLES[tablename] += "%s, "
linter 抱怨我没有使用变量“key”。这并不能阻止它工作,但它表明可能有更好的方法来做到这一点。
我试过这个:
TABLES[tablename].extend("%s, ", len(table[0].keys()))
这引发了“str”对象没有属性“extend”的异常
没有更好的方法 str += "value" * x 吗?