3

次のコードを使用して、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()

この質問と他のリソースを参照してきました。いずれにせよ、次のエラーが発生します。その理由は何でしょう?

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

1 に答える 1

7

を で上書きしたfrom pandas.io import sqlためsql = """...、は文字列になり、関数を保持するモジュールではsqlなくなりました。pandaswrite_frame


編集: 表示されるAttributeError: 'numpy.int64' object has no attribute 'replace'エラーは、整数の列ラベルを使用しているためです (これはバグです)。列のラベルを別のものに設定してみてください。

df.columns = ['COL1', 'COL2', 'COL3']
于 2013-07-23T09:45:15.287 に答える