【问题标题】:Python: Append to String N timesPython:附加到字符串 N 次
【发布时间】:2020-02-04 03:13:27
【问题描述】:

我的脚本解析 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 ?

【问题讨论】:

    标签: string extend string-iteration


    【解决方案1】:

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

    类似:

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

    【讨论】:

    • 这正是我想要的!谢谢!
    猜你喜欢
    • 2015-08-05
    • 1970-01-01
    • 1970-01-01
    • 2015-05-31
    • 2019-02-13
    • 2023-03-22
    • 1970-01-01
    • 1970-01-01
    • 2021-09-26
    相关资源
    最近更新 更多