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 虚拟机打包apk出现错误
  • ¥30 最小化遗憾贪心算法上界
  • ¥15 用visual studi code完成html页面
  • ¥15 聚类分析或者python进行数据分析
  • ¥15 逻辑谓词和消解原理的运用
  • ¥15 三菱伺服电机按启动按钮有使能但不动作
  • ¥15 js,页面2返回页面1时定位进入的设备
  • ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝