python – 将Pandas DataFrame写入MySQL数据库
发布时间:2020-12-20 11:28:30 所属栏目:Python 来源:网络整理
导读:我正在尝试使用以下代码将pandas数据帧写入 MySQL数据库. import pandas as pdimport numpy as npfrom pandas.io import sqlimport MySQLdbdf = pd.DataFrame([[1.1,1.1,2.6,2.5,3.4,3.3],list('AAABBBBABCBDDD'),[1.1,1.7,3.3,3.8,4.0,4.2,4.3,4.5,4.6,4.7,
我正在尝试使用以下代码将pandas数据帧写入
MySQL数据库.
import pandas as pd import numpy as np from pandas.io import sql import MySQLdb df = pd.DataFrame([[1.1,1.1,2.6,2.5,3.4,3.3],list('AAABBBBABCBDDD'),[1.1,1.7,3.3,3.8,4.0,4.2,4.3,4.5,4.6,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,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'] (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |