簡體   English   中英

在MySQL中插入列表的Python列表

[英]Insert a Python list of lists in MySQL

我有一個龐大的列表(A),由多個子列表(x,y,... n)組成,每個子列表都包含['a','b','c','d','e' ,'f','g']元素。 我想將所有子列表的所有內容傳輸到db表(使用MySQLdb模塊),但無法弄清楚如何實現此目的。 我現在正在做的事情是這樣的:

 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()

但是沒有成功..有什么幫助嗎?

我想知道該行注釋在您的邏輯中是否正確?

 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)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM