Python で CSV データを MySQL にロードする
Python を使用して CSV データを MySQL テーブルにロードしようとすると、次のようなシナリオが発生する可能性があります。コードはエラーなしで実行されますが、テーブルへのデータの挿入に失敗します。この問題に対処するには、このプロセスにおける mydb.commit() の役割を理解することが重要です。
まず、mydb.connect() 関数がデータベースへの接続を確立します。カーソルが作成されると、CSV データが読み取られ、INSERT INTO ステートメントを使用してテーブルに挿入されます。ただし、挿入後に mydb.commit() を実行して変更をデータベースに保存することが不可欠です。この手順を実行しないと、データはコミットされていない状態のままになり、テーブルに表示されません。
mydb.commit() が追加された変更されたコードは次のとおりです。
import csv import MySQLdb mydb = MySQLdb.connect(host='localhost', user='root', passwd='', db='mydb') cursor = mydb.cursor() csv_data = csv.reader(file('students.csv')) for row in csv_data: cursor.execute('INSERT INTO testcsv(names, \ classes, mark )' \ 'VALUES("%s", "%s", "%s")', row) mydb.commit() # Save changes to database #close the connection to the database. cursor.close() print "Done"
mydb.commit() を使用すると、データが MySQL テーブルに正常に挿入されたことを確認できます。
以上が私の Python コードが CSV データを MySQL に挿入しないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。