Python:附加到字符串 N 次



我的脚本解析JSON文件的目录,并在数据库中为每个文件创建表。 我现在正在努力从这些文件导入数据。 为了构建具有可变长度列数的 SQL 查询字符串,我需要在查询字符串后附加每列的 %s,然后用 "(" 关闭查询字符串,并将其返回到导入记录函数。

工作代码如下所示:

TABLES[tablename] += (
"INSERT INTO " + tablename + str(tuple(table[0].keys())).replace("'", "")
)
TABLES[tablename] += "nVALUESn("

然后是有问题的部分:

for key in table[0].keys():
key = key  # just to shut the linter up...
TABLES[tablename] += "%s, "

棉绒抱怨我没有使用变量"key"。 这并不妨碍它工作,但它表明可能有更好的方法来做到这一点。

我试过这个:

TABLES[tablename].extend("%s, ", len(table[0].keys()))

这引发了一个异常,即"str"对象没有属性"extend">

难道没有更好的方法来str +="值"* x吗?

您可以尝试一次性变量_(其他人可能有更好的描述(并检查您的 linter 是否抱怨不使用它。

像这样:

for _ in table[0].keys():
TABLES[tablename] += "%s, "

相关内容

  • 没有找到相关文章

最新更新