Maison > Questions et réponses > le corps du texte
import pandas as pd
import mysql.connector as cnmsq
try:
cnkun = cnmsq.connect(user='root',
password='123456',
host='127.0.0.1',
database='dbkun')
except:
print('failed connect!')
table = pd.read_excel(r'D:\source.xls')
names = list(table['种名'])
acc_or_syn = [None]*len(table)
acc_family = [None]*len(table)
acc_genus = [None]*len(table)
acc_names = [None]*len(table)
acc_fnames = [None]*len(table)
aos_query = "SELECT is_accepted_name, accepted_id FROM kun_species WHERE species_name=%s"
acc_query = "SELECT species_family, species_genus, species_name, species_full_name FROM kun_species WHERE species_id=%s"
cursor = cnkun.cursor()
for i, name in enumerate(names):
cursor.execute(aos_query, (name.strip(),))
for w, s in cursor:
acc_or_syn[i] = w
cursor.execute(acc_query, (s,))
acc_tuple = cursor.fetchone()
acc_family[i], acc_genus[i], acc_names[i], acc_fnames[i] = acc_tuple
上面这段代码的逻辑是从source.xlsx
文件中读取某一列,然后根据该列的每一行字符串从mysql
数据中找出该字符串及其对应的值,对于绝大部分source.xlsx
列中的字符串,在mysql
数据表中都仅有一条记录与之对应,也就是说大多数情况下cursor.execute(aos_query, (name.strip(),))
内只有一行记录,但当mysql
中遇到执行cursor.execute(aos_query, (name.strip(),))
出现多于一行记录时,程序就会出错:
Traceback (most recent call last):
File "D:\...py", line 43, in <module>
cursor.execute(acc_query, (s,))
File "C:\Users\...\Anaconda3\lib\site-packages\mysql\connector\cursor.py", line 476, in execute
raise errors.InternalError("Unread result found.")
mysql.connector.errors.InternalError: Unread result found.
请问这是什么原因。
天蓬老师2017-04-17 17:27:27
for i, name in enumerate(names):
cursor.execute(aos_query, (name.strip(),)) // 假如这里读到多行数据,结果集缓存在某个地方
// 下面从游标中读取数据,相当于执行了fetchone,如果有多条数据,那游标对应位置之后还有数据
for w, s in cursor: // 可以改为**for w, s in cursor.fetchall()**返回所有数据
acc_or_syn[i] = w
// 游标对应位置还有数据,这里又进行查询会导致上次查询的数据丢失,所以给你抛异常
cursor.execute(acc_query, (s,))
acc_tuple = cursor.fetchone()
acc_family[i], acc_genus[i], acc_names[i], acc_fnames[i] = acc_tuple