我正在尝试使用 pymysql
将 mySQL 查询结果存储在 pandas DataFrame 中,但在构建数据帧时遇到错误。 在这里 和 这里 发现了类似的问题,但看起来有 pymysql
抛出特定错误:
import pandas as pd
import datetime
import pymysql
# dummy values
connection = pymysql.connect(user='username', password='password', databse='database_name', host='host')
start_date = datetime.datetime(2017,11,15)
end_date = datetime.datetime(2017,11,16)
try:
with connection.cursor() as cursor:
query = "SELECT * FROM orders WHERE date_time BETWEEN %s AND %s"
cursor.execute(query, (start_date, end_date))
df = pd.DataFrame(data=cursor.fetchall(), index = None, columns = cursor.keys())
finally:
connection.close()
回报: AttributeError: 'Cursor' object has no attribute 'keys'
如果我删除 index
和 columns
参数:
try:
with connection.cursor() as cursor:
query = "SELECT * FROM orders WHERE date_time BETWEEN %s AND %s"
cursor.execute(query, (start_date, end_date))
df = pd.DataFrame(cursor.fetchall())
finally:
connection.close()
回报 ValueError: DataFrame constructor not properly called!
提前致谢!
原文由 msoderstrom 发布,翻译遵循 CC BY-SA 4.0 许可协议
为此使用 Pandas.read_sql() :