Heim  >  Fragen und Antworten  >  Hauptteil

Der Python-Datenrahmen kann nicht in MySQL geladen werden

Ich versuche, einen Python-Datenrahmen in MySQL zu laden. Es wird der Fehler „Formatargument konnte nicht verarbeitet werden; Python ‚Zeitstempel‘ kann nicht in MySQL-Typ konvertiert werden“ zurückgegeben. Ich bin mir nicht sicher, worum es geht.

import pandas as pd
from datetime import date
import mysql.connector
from mysql.connector import Error
def priceStock(tickers):
  today = pd.to_datetime("today").strftime("%Y-%m-%d")
  for ticker in tickers:
    conn = mysql.connector.connect(host='103.200.22.212', database='analysis_stock', user='analysis_PhamThiLinhChi', password='Phamthilinhchi')
    
    new_record = stock_historical_data(ticker, '2018-01-01', today)
    new_record.insert(0, 'ticker', ticker)
    table = 'priceStock'
    cursor = conn.cursor()
        #loop through the data frame
    for i,row in new_record.iterrows():
    #here %s means string values 
        sql = "INSERT INTO " + table + " VALUES (%s,%s,%s,%s,%s,%s,%s)"

        #đoán chắc là do format time từ python sang sql ko khớp 
        cursor.execute(sql, tuple(row))
        print("Record inserted")
        # the connection is not auto committed by default, so we must commit to save our changes
        conn.commit()
priceStock(['VIC'])

P粉156983446P粉156983446401 Tage vor558

Antworte allen(1)Ich werde antworten

  • P粉797004644

    P粉7970046442023-09-15 09:11:46

    您可以使用 to_sql to_sql 使用 SQLAlchemy 并且 SQLAlchemy 支持 MySQL,因此下面的代码应该可以工作

    import pandas as pd
    from datetime import date
    import mysql.connector
    from mysql.connector import Error
    import sqlalchemy
    
    def priceStock(tickers):
      today = pd.to_datetime("today").strftime("%Y-%m-%d")
      for ticker in tickers:
        conn = sqlalchemy.create_engine('mysql+mysqlconnector://analysis_PhamThiLinhChi:Phamthilinhchi@103.200.22.212')
        # conn = mysql.connector.connect(host='103.200.22.212', database='analysis_stock', user='analysis_PhamThiLinhChi', password='Phamthilinhchi')
        
        new_record = stock_historical_data(ticker, '2018-01-01', today)
        new_record.insert(0, 'ticker', ticker)
        table = 'priceStock'
        # cursor = conn.cursor()
        new_record.to_sql(table, con=conn, if_exists='append')
            #loop through the data frame
        # for i,row in new_record.iterrows():
        # #here %s means string values 
        #     sql = "INSERT INTO " + table + " VALUES (%s,%s,%s,%s,%s,%s,%s)"
    
        #     #đoán chắc là do format time từ python sang sql ko khớp 
        #     cursor.execute(sql, tuple(row))
        #     print("Record inserted")
        #     # the connection is not auto committed by default, so we must commit to save our changes
        #     conn.commit()
    priceStock(['VIC'])

    要查看更新的行,请使用以下代码:

    from sqlalchemy import text
    conn = sqlalchemy.create_engine('mysql+mysqlconnector://analysis_PhamThiLinhChi:Phamthilinhchi@103.200.22.212')
    with conn.connect() as con:
       df = con.execute(text("SELECT * FROM priceStock")).fetchall()
       print(df)

    Antwort
    0
  • StornierenAntwort