Swaggy_Z0306 2019-12-10 15:33 采纳率: 0%
浏览 757

error_message:insertMysqlseghist() takes 4 positional arguments but 5 were given

从oracle获取数据插入mysql的脚本,大神帮忙看一下代码哪里有问题

sql语句:Insert_dblinkSql = insert into kt_collectoracle (owner,db_link,username,host,created) values ('%s','%s','%s','%s','%s')

def insertMysqlseghist(self,oracleDatadb,oracleDatacur,OracleDataTuple):

  for OracleData in OracleDataTuple:
      try:
          oracleDatacur.execute(self.Insert_dblinkSql%(OracleData[0],
                                                       OracleData[1],OracleData[2],OracleData[3],OracleData[4]))

          oracleDatadb.commit()
      except Exception as e:
          oracleDatadb.rollback()
          logger_data_message.debug('error: '+str(e)+'\n')

  • 写回答

1条回答 默认 最新

  • 憧憬blog 2023-03-15 04:20
    关注

    根据代码和错误信息,可以看到问题出在 insertMysqlseghist 函数中。具体来说,这个函数定义时只有 3 个参数(self、oracleDatadb 和 oracleDatacur),但是在调用时却传入了 4 个参数(self、oracleDatadb、oracleDatacur 和 OracleDataTuple)。这样的话,Insert_dblinkSql 中的 %s 占位符无法正确地与 OracleDataTuple 中的数据匹配,从而报出了错误信息:insertMysqlseghist() takes 4 positional arguments but 5 were given。

    为了解决这个问题,你需要修改 insertMysqlseghist 函数的定义,让它接受 4 个参数,或者在函数调用时只传入前 3 个参数。另外,你也需要检查 OracleDataTuple 中的数据是否与 Insert_dblinkSql 中的占位符顺序和个数一致,否则可能会引起其他的错误。

    评论

报告相同问题?

悬赏问题

  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作