• Empleos
  • Sobre nosotros
  • Empleos
    • Inicio
    • Empleos
    • Cursos y retos
  • Empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

279
Vistas
Django python Cómo insertar un json que contiene varios objetos en postgresql

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í .

over 3 years ago · Santiago Trujillo
1 Respuestas
Responde la pregunta

0

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

over 3 years ago · Santiago Trujillo Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda