ホームページ >データベース >mysql チュートリアル >私の Python コードが CSV データを MySQL に挿入しないのはなぜですか?

私の Python コードが CSV データを MySQL に挿入しないのはなぜですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-27 05:03:141010ブラウズ

Why Doesn't My Python Code Insert CSV Data into MySQL?

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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。