当我使用python编程语言和mysql数据库执行以下代码时
cursor.execute("select max(propernoun_SRNO) from tblauto_tagged")
starting_index = cursor.fetchone()
ending_index = starting_index +len(s)
我得到以下错误:
Traceback (most recent call last):
File "<pyshell#0>", line 1, in <module>
batch(1,1)
File "C:\Users\vchauhan\Dropbox\Code\proper_noun_function_batch_file_mysql_sept_12.py", line 97, in batch
ending_index = starting_index +len(s)
TypeError: unsupported operand type(s) for +: 'pyodbc.Row' and 'int'
最佳答案
问题
这里的问题是,您正在将pyodbc.Row
实例(由.fetchone()
返回)分配给starting_index
,这使得无法将其添加到整数(因此是“type error:unsupported operand type(s)”错误)。
解决方案
尝试替换此行:
starting_index = cursor.fetchone()
用这句话:
starting_index = cursor.fetchone()[0]
更多阅读
PEP 249 - Python Database API Specification v2.0(特别是关于
fetchone()
的部分)