python写入mysql数据库_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']

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值