【发布时间】:2013-06-07 20:28:46
【问题描述】:
我正在尝试将 python 变量插入到 python 脚本中的 MySQL 表中,但它不起作用。这是我的代码
add_results=("INSERT INTO account_cancel_predictions"
"(account_id,21_day_probability,flagged)"
"Values(%(account_id)s,%(21_day_probability)s,%(flagged)s)")
data_result={
'account_id':result[1,0],
'21_day_probability':result[1,1],
'flagged':result[1,2]
}
cursor.execute(add_results,data_result)
cnx.commit()
cursor.close()
cnx.close()
这会出错
ProgrammingError: Failed processing pyformat-parameters; 'MySQLConverter' object has no attribute '_float64_to_mysql'
但是,当我将变量名称 result[1,0]、result[1,1] 和 result[1,2] 替换为它们的实际数值时,它确实有效。我怀疑 python 传递的是实际的变量名,而不是它们持有的值。我该如何解决这个问题?
【问题讨论】:
-
connection = engine.connect() connection.execute(""" update Players set Gold =(?) where Name=(?)""",(gold,name)) ,也许只是一个fanboy 的事情,但我倾向于将 sqlalchemy 与 python 一起使用,这往往会简化大部分内容,而且我从来没有遇到过使用通配符的问题
标签: python mysql insert mysql-connector-python