Me gustaría insertar un json que contenga varias publicaciones en mi base de datos. Quiero crear un campo para cada publicación. Por el momento logré insertar un json que contiene una sola publicación, sin embargo cuando intento con dos me da error:
Python de la secuencia de comandos:
fichier = open("result2.json","r") filedata = json.load(fichier) #for '{' in filedata: #print "ici un {" prod = Production() prod.cle = filedata.get("UT") prod.titre = filedata.get("TITRE") prod.publis = filedata prod.maj = timezone.now() prod.save() fichier.close()resultado2.json
{ "UT": "WOS:123456", "TI": "firstpubli", "DT": "journal", "PY": "2016", "TITRE" :"firstpubli2016", "AU": "me, you" }¿Qué hace [ingrese la descripción de la imagen aquí] [1]
Ahora si pongo 2 publicaciones en result2.json:
{ "UT": "WOS:123456", "TI": "firstpubli", "DT": "journal", "PY": "2016", "TITRE" :"firstpubli2016", "AU": "me, you" } { "UT": "WOS:78910", "TI": "secondpubli", "DT": "journal", "PY": "2016", "TITRE" :"secondpubli2016", "AU": "me, you" }Cuando ejecuto el script de python para insertar los datos, tengo este error
Traceback (most recent call last): File "test.py", line 45, in <module> filedata = json.load(fichier) File "/usr/lib/python2.7/json/__init__.py", line 291, in load **kw) File "/usr/lib/python2.7/json/__init__.py", line 339, in loads return _default_decoder.decode(s) File "/usr/lib/python2.7/json/decoder.py", line 367, in decode raise ValueError(errmsg("Extra data", s, end, len(s))) ValueError: Extra data: line 12 column 2 - line 21 column 1 (char 143 - 282)Y no se inserta nada en la base de datos. Mi objetivo es obtener como en esta imagen, 2 producciones, cuando tenga 2 producciones en mi json , ingrese la descripción de la imagen aquí .
Su archivo no es una cadena json. Si desea insertar más de un objeto, debe incluir una lista de usuarios.
su archivo debe ser como sigue:
[{ "UT": "WOS:123456", "TI": "firstpubli", "DT": "journal", "PY": "2016", "TITRE" :"firstpubli2016", "AU": "me, you" }, { "UT": "WOS:78910", "TI": "secondpubli", "DT": "journal", "PY": "2016", "TITRE" :"secondpubli2016", "AU": "me, you" }]
También deberías cambiar tu código así:
filedata = json.load(fichier) for f in filedata: //object insertion here