Problème json

Signaler
Messages postés
18
Date d'inscription
mercredi 20 février 2019
Statut
Membre
Dernière intervention
24 mars 2021
-
Messages postés
588
Date d'inscription
mardi 16 avril 2013
Statut
Membre
Dernière intervention
26 mars 2021
-
Bonjour,

J'ai un problème dans un de mes script en python avec du json.
Voilà l'erreur que je reçois :
Traceback (most recent call last):
File "tip_ws.py", line 33, in <module>
data_j = json.loads(data)
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 364, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
File "/usr/lib/python2.7/json/decoder.py", line 380, in raw_decode
obj, end = self.scan_once(s, idx)
ValueError: Expecting object: line 1 column 156 (char 155)


Est-ce que vous pourriez m'aider ? Merci beaucoup déjà d'avance !



Voilà le code du script :
#!/usr/bin/env python
# -*- coding: utf-8 -*-

from time import sleep
import serial
import requests
import json
import time

url='myURL'

data = ""
letter_last=""

ser = serial.Serial ("/dev/ttyS0", 9600) #Open port with baud rate
while True:
data += ser.read()
#received_data = ser.read() #read serial port
#sleep(0.03)
#data_left = ser.inWaiting() #check for remaining byte
#received_data += ser.read(data_left)
#received_data = received_data.strip()


#Récupération du dernier caractère
letter_last = data[-1]

#Si dernier caractère est égal à "]" le message est terminé !
if letter_last == "]":
#Récupération du contenu sans les accolades "[" et "]"
data = data[1:-1]
#Decodage des données en JSON
data_j = json.loads(data)

#Récupération des données
password = "mypassword"
stationmeteo = data_j.get('stationMeteo')
pression = data_j.get('pression')
temperature = data_j.get('temperature')
humidite = data_j.get('humidite')
luminosite = data_j.get('luminosite')
uv = data_j.get('uv')
pluie = data_j.get('pluie')
qualiteAir = data_j.get('qualiteAir')
vent = data_j.get('vent')

#Préparation de l'objet JSON à envoyer dans la requête HTTP au serveur
content = {
'password' : password,
'stationMeteo' : stationmeteo,
'pression' : pression,
'temperature' : temperature,
'humidite' : humidite,
'luminosite' : luminosite,
'uv' : uv,
'pluie' : pluie,
'qualiteAir' : qualiteAir,
'vent' : vent
}

#Création de la requête HTTP avec l'url et l'objet JSON
response = requests.post(url, content)

#Affichage des informations
print ('AJOUT DONNEES - ' + time.strftime("%Y/%m/%d %H:%M:%S") + '\n')
print (content)
print ('\n')
print (response.json().get('response'))
print ('---------------------------------')

#Réinitialisation des données
data = ""
letter_last = ""
content = ""
data_j = ""

1 réponse

Messages postés
588
Date d'inscription
mardi 16 avril 2013
Statut
Membre
Dernière intervention
26 mars 2021
130
Salut !
Désolé du retard dans la réponse.

Pour ce problème, il faudrait sûrement mieux que tu regardes le format de tes données json. Visiblement c'est dans la lecture du fichier que Python crash...

Essaye d'afficher les données que tu veux parse de JSON pour voir si la syntaxe ne pose pas problème par exemple.