0

複数のサブリスト (x、y、... n) で構成される巨大なリスト (A) があり、各サブリストには ['a'、'b'、'c'、'd'、'e' が含まれています。 、「f」、「g」] 要素。すべてのサブリストのすべてのコンテンツを (MySQLdb モジュールを使用して) db テーブルに転送したいのですが、これを実現する方法がわかりません。私が今していることは次のようなものです:

 import MySQLdb

 db = MySQLdb.connect("localhost","root","","test")
 cursor = db.cursor()

 for u in A:
     for x1,x2,x3,x4,x5,x6,x7,x8 in u:
           cursor.execute("INSERT INTO logs(date, time, pri, method, action, client, unknown1, unknown2) VALUES ('%s','%s','%s','%s','%s','%s','%s','%s')" % (x1, x2, x3, x4, x5, x6, x7, x8))
           db.commit()

 db.close()

しかし、成功していません..何か助けはありますか?

4

1 に答える 1

0

行のコメントアウトはあなたのロジックで正しいのだろうか?

 for u in A:
     #for x1,x2,x3,x4,x5,x6,x7,x8 in u:
           cursor.execute("INSERT INTO logs(date, time, pri, method, action, client, unknown1, unknown2) VALUES ('%s','%s','%s','%s','%s','%s','%s','%s')" % (x1, x2, x3, x4, x5, x6, x7, x8))

次のようにする可能性が高くなります。

 import MySQLdb

 db = MySQLdb.connect("localhost","root","","test")
 cursor = db.cursor()

 cursor.executemany("INSERT INTO logs(date, time, pri, method, action, client, unknown1, unknown2) VALUES (%s, %s, %s, %s, %s, %s, %s, %s)", A)
 db.commit()

 db.close()

executemany で%sを使用すると、MySQLdb が汚い作業を実行できるようになります (エスケープ文字列を 'string' にしますが、int は int のままにします。たとえば、"str" -> "'str'"、"1" -> 1)。

于 2013-05-04T04:15:07.117 に答える