Ik denk dat de opmerking over het gebruik hiervan met MySQL niet helemaal compleet is. MySQLdb doet geen parametervervanging in de kolommen, alleen de waarden (IIUC) - dus misschien meer zoals
placeholders = ', '.join(['%s'] * len(myDict))
columns = ', '.join(myDict.keys())
sql = "INSERT INTO %s ( %s ) VALUES ( %s )" % (table, columns, placeholders)
# valid in Python 2
cursor.execute(sql, myDict.values())
# valid in Python 3
cursor.execute(sql, list(myDict.values()))
Je ontsnapt echter niet aan de kolommen, dus misschien wil je ze eerst controleren....
Zie http://mail.python.org/pipermail/tutor/ 2010-december/080701.html voor een completere oplossing