微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

python – 将Pandas DataFrame写入MySQL数据库

我正在尝试使用以下代码将pandas数据帧写入MySQL数据库.

import pandas as pd
import numpy as np
from pandas.io import sql
import MysqLdb

df = pd.DataFrame([[1.1, 1.1, 1.1, 2.6, 2.5, 3.4,2.6,2.6,3.4,3.4,2.6,1.1,1.1,3.3], list('AAABBBBABCBDDD'), [1.1, 1.7, 2.5, 2.6, 3.3, 3.8,4.0,4.2,4.3,4.5,4.6,4.7,4.7,4.8]]).T

db = MysqLdb.connect("192.168.56.101","nilani","123","test")
cursor = db.cursor()

cursor.execute("DROP TABLE IF EXISTS TEST")

sql = """CREATE TABLE TEST (
         ID  INT NOT NULL,
         COL1 CHAR(20),
         COL2 CHAR(20),  
         COL3 CHAR(20))"""

cursor.execute(sql)

sql.write_frame(df, con=db, name='TEST', flavor='MysqL')

db.close()

我一直在提及this问题和其他资源.我有任何方式得到以下错误.会是什么原因?

sql.write_frame(df, con=db, name='TEST', flavor='MysqL')
AttributeError: 'str' object has no attribute 'write_frame'

解决方法:

你用sql =“”“覆盖了pandas.io import sql,所以sql现在是一个字符串,不再是一个保存write_frame函数的pandas模块.

编辑:AttributeError:’numpy.int64’对象没有属性’替换’错误你得到的是由于你使用整数列标签(这是一个错误).尝试将列标签设置为其他内容,例如:

df.columns = ['COL1', 'COL2', 'COL3']

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐