森屿安年 2021-10-06 18:18 采纳率: 0%
浏览 94

executemany执行insert语句报错not enough arguments for format string

Python使用pymysql执行insert语句报错、

content = ['17346204945874944', '信维通信', '300136', 'question', 107, '制造业', '2012-05-31 13:13:30', '2012-05-31 21:05:10', '苹果',
 'answer',104, '信维通信', '2012-05-31 21:05:10', 7]

def save_to_cninfo(course_date):
    sql_course = """INSERT INTO cninfo VALUES (%s,%s,%s,%s,%s,%s,str_to_date(if(%s='',null,%s),'%%Y-%%m-%%d %%H:%%i:%%s.%%f'),
str_to_date(if(%s='',null,%s),'%%Y-%%m-%%d %%H:%%i:%%s.%%f'),%s,%s,%s,%s,
str_to_date(if(%s='',null,%s),'%%Y-%%m-%%d %%H:%%i:%%s.%%f'),%s)"""
    print(sql_course)
    print(course_date)
    cur.executemany(sql_course, course_date)

def save_mysql(content):
    course_date = []
    for item in content:
        if not check_es_exist(item["indexId"]):
            course_value = (
                item["indexId"], item["companyShortName"], item["stockCode"], item["mainContent"], mainContentCount,
                item["trade"][0],
                date_format(item["pubDate"]), date_format(item["updateDate"]), item["authorName"],
                item["attachedContent"],
                attachedContentCount, item["attachedAuthor"], date_format(item["attachedPubDate"]), dateDiff)
            course_date.append(course_value)
    save_to_cninfo(course_date)

报错如下:

Traceback (most recent call last):
  File "C:\Users\LiuDapao\AppData\Roaming\JetBrains\IntelliJIdea2021.1\plugins\python\helpers\pydev\pydevd.py", line 1483, in _exec
    pydev_imports.execfile(file, globals, locals)  # execute the script
  File "C:\Users\LiuDapao\AppData\Roaming\JetBrains\IntelliJIdea2021.1\plugins\python\helpers\pydev\_pydev_imps\_pydev_execfile.py", line 18, in execfile
    exec(compile(contents+"\n", file, 'exec'), glob, loc)
  File "D:/Document/IDEA space/python/Crawlers/TestResponse.py", line 171, in <module>
    main(index)
  File "D:/Document/IDEA space/python/Crawlers/TestResponse.py", line 162, in main
    save_mysql(content)
  File "D:/Document/IDEA space/python/Crawlers/TestResponse.py", line 149, in save_mysql
    save_to_cninfo(course_date)
  File "D:/Document/IDEA space/python/Crawlers/TestResponse.py", line 113, in save_to_cninfo
    cur.executemany(sql_course, course_date)
  File "D:\App\application\anaconda3\lib\site-packages\pymysql\cursors.py", line 182, in executemany
    self.rowcount = sum(self.execute(query, arg) for arg in args)
  File "D:\App\application\anaconda3\lib\site-packages\pymysql\cursors.py", line 182, in <genexpr>
    self.rowcount = sum(self.execute(query, arg) for arg in args)
  File "D:\App\application\anaconda3\lib\site-packages\pymysql\cursors.py", line 146, in execute
    query = self.mogrify(query, args)
  File "D:\App\application\anaconda3\lib\site-packages\pymysql\cursors.py", line 125, in mogrify
    query = query % self._escape_args(args, conn)
TypeError: not enough arguments for format string

debug去看了executemany的源码、发现在m = RE_INSERT_VALUES.match(query) 这一步的时候、m的值为none

img

目前不知道怎么解决、求指导、

  • 写回答

1条回答 默认 最新

  • CSDN专家-link 2021-10-06 18:27
    关注

    应该是说你格式化字符串的时候,给出的参数数量不够啊

    评论

报告相同问题?

问题事件

  • 修改了问题 10月6日
  • 创建了问题 10月6日

悬赏问题

  • ¥15 编辑cmake lists 明明写了project项目名,但是还是报错怎么回事
  • ¥15 关于#计算机视觉#的问题:求一份高质量桥梁多病害数据集
  • ¥15 特定网页无法访问,已排除网页问题
  • ¥50 如何将脑的图像投影到颅骨上
  • ¥15 提问一个关于vscode相关的环境配置问题,就是输入中文但是显示不出来,代码在idea可以显示中文,但在vscode不行,不知道怎么配置环境
  • ¥15 netcore使用PuppeteerSharp截图
  • ¥20 这张图页头,页脚具体代码该怎么写?
  • ¥15 关于#sql#的问题,请各位专家解答!
  • ¥20 WPF MVVM模式 handycontrol 框架, hc:SearchBar 控件 Text="{Binding NavMenusKeyWords}" 绑定取不到值
  • ¥15 需要手写数字信号处理Dsp三个简单题 不用太复杂