如何在Python中使用executemany将一个字典列表插入到MySQL中

6 浏览
0 Comments

如何在Python中使用executemany将一个字典列表插入到MySQL中

我目前正在使用MySQL和Python从网页上爬取数据。具体来说,我正在提取表格数据并将其插入到我的数据库中。我的当前解决方案可以工作,但我觉得它非常低效,如果不重写代码,很可能会锁定我的数据库。这是我目前使用的代码(部分代码):

itemBank = []
for row in rows:
    itemBank.append((tempRow2,tempRow1,tempRow3,tempRow4)) #追加数据
# itemBank是一个包含每行表格数据的字典列表。例如:
('Item_Name':"Tomatoes",'Item_Price':"10",'Item_In_Stock':"10",'Item_Max':"30")
for item in itemBank:
    tempDict1 = item[0]
    tempDict2 = item[1]
    tempDict3 = item[2]
    tempDict4 = item[3]
    q = """ INSERT IGNORE INTO
         TABLE1   
        (
           Item_Name,
           Item_Price,
           Item_In_Stock,
           Item_Max,
           Observation_Date
         ) VALUES (
           "{0}",
           "{1}",
           "{2}",
           "{3}",
           "{4}"
           )
        """.format(tempDict1['Item_Name'],tempDict2['Item_Price'],tempDict3['Item_In_Stock'],
                   tempDict4['Item_Max'],getTimeExtra)
    try:
        x.execute(q)
        conn.commit()
    except:
        conn.rollback()

执行每行表格数据很麻烦。我尝试使用executemany,但似乎无法正确访问字典的值。

那么,我该如何使用executemany在给定我的数据结构的情况下插入到数据库中?

0