gpt4 book ai didi

python - 将 Pandas DataFrame 写入 MySQL 数据库

转载 作者:可可西里 更新时间:2023-11-01 07:52:52 27 4
gpt4 key购买 nike

我正在尝试使用以下代码将 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 = """... 覆盖了 from pandas.io import sql,所以 sql 现在是一个字符串不再是包含 write_frame 函数的 pandas 模块。


编辑:您得到的 AttributeError: 'numpy.int64' object has no attribute 'replace' 错误是由于您使用整数列标签(这是一个错误)。尝试将列标签设置为其他内容,例如:

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

关于python - 将 Pandas DataFrame 写入 MySQL 数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17806649/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com