J'essaye d'insérer des données d'un dictionnaire dans une base de données. Je souhaite parcourir les valeurs et les formater en conséquence, en fonction du type de données. Voici un extrait du code que j'utilise:
def _db_inserts(dbinfo):
try:
rows = dbinfo['datarows']
for row in rows:
field_names = ",".join(["'{0}'".format(x) for x in row.keys()])
value_list = row.values()
for pos, value in enumerate(value_list):
if isinstance(value, str):
value_list[pos] = "'{0}'".format(value)
elif isinstance(value, datetime):
value_list[pos] = "'{0}'".format(value.strftime('%Y-%m-%d'))
values = ",".join(value_list)
sql = "INSERT INTO table_foobar ({0}) VALUES ({1})".format(field_names, values)
except Exception as e:
print 'BARFED with msg:',e
Lorsque j'exécute l'algo en utilisant des exemples de données (voir ci-dessous), j'obtiens l'erreur:
TypeError: élément de séquence 0: chaîne attendue, int trouvé
Un exemple de données value_list qui donne l'erreur ci-dessus est:
value_list = [377, -99999, -99999, 'f', -99999, -99999, -99999, 1108.0999999999999, 0, 'f', -99999, 0, 'f', -99999, 'f', -99999, 1108.0999999999999, -99999, 'f', -99999, 'f', -99999, 'f', 'f', 0, 1108.0999999999999, -99999, -99999, 'f', 'f', 'f', -99999, 'f', '1984-04-02', -99999, 'f', -99999, 'f', 1108.0999999999999]
What am I doing wrong?
values = ",".join(map(str, value_list))