Obecnie mam ten słownik wydrukowany przy użyciu pprint
:
{'AlarmExTempHum': '\x00\x00\x00\x00\x00\x00\x00\x00',
'AlarmIn': 0,
'AlarmOut': '\x00\x00',
'AlarmRain': 0,
'AlarmSoilLeaf': '\x00\x00\x00\x00',
'BarTrend': 60,
'BatteryStatus': 0,
'BatteryVolts': 4.751953125,
'CRC': 55003,
'EOL': '\n\r',
'ETDay': 0,
'ETMonth': 0,
'ETYear': 0,
'ExtraHum1': None,
'ExtraHum2': None,
'ExtraHum3': None,
'ExtraHum4': None,
'ExtraHum5': None,
'ExtraHum6': None,
'ExtraHum7': None,
'ExtraTemp1': None,
'ExtraTemp2': None,
'ExtraTemp3': None,
'ExtraTemp4': None,
'ExtraTemp5': None,
'ExtraTemp6': None,
'ExtraTemp7': None,
'ForecastIcon': 2,
'ForecastRuleNo': 122,
'HumIn': 31,
'HumOut': 94,
'LOO': 'LOO',
'LeafTemps': '\xff\xff\xff\xff',
'LeafWetness': '\xff\xff\xff\x00',
'NextRec': 37,
'PacketType': 0,
'Pressure': 995.9363359295631,
'RainDay': 0.0,
'RainMonth': 0.0,
'RainRate': 0.0,
'RainStorm': 0.0,
'RainYear': 2.8,
'SoilMoist': '\xff\xff\xff\xff',
'SoilTemps': '\xff\xff\xff\xff',
'SolarRad': None,
'StormStartDate': '2127-15-31',
'SunRise': 849,
'SunSet': 1611,
'TempIn': 21.38888888888889,
'TempOut': 0.8888888888888897,
'UV': None,
'WindDir': 219,
'WindSpeed': 3.6,
'WindSpeed10Min': 3.6}
Kiedy to robię:
import json
d = (my dictionary above)
jsonarray = json.dumps(d)
Otrzymuję ten błąd: 'utf8' codec can't decode byte 0xff in position 0: invalid start byte
python
python-2.7
HyperDevil
źródło
źródło
\xff
Odpowiedzi:
Jeśli nie masz nic przeciwko symbolom niedrukowalnym w pliku json, dodaj
ensure_ascii=False
dodumps
call.źródło
indent=n
do opcji ładnego wydruku, gdzien
jest liczba spacji do wcięciasure_ascii = False tak naprawdę odsuwa problem tylko do etapu dekodowania:
Ostatecznie nie możesz przechowywać nieprzetworzonych bajtów w dokumencie JSON, więc będziesz chciał użyć pewnych środków do jednoznacznego zakodowania sekwencji dowolnych bajtów jako ciągu ASCII - na przykład base64.
źródło
b64encode
. Na przykład dla ciągu 256 znakóws = ''.join(chr(i) for i in xrange(256))
,len(json.dumps(b64encode(s))) == 346
vslen(json.dumps(s.decode('latin1'))) == 1045
.Jeśli używasz Pythona 2, nie zapomnij dodać komentarza do kodowania plików UTF-8 w pierwszej linii skryptu.
To rozwiąże niektóre problemy z Unicode i ułatwi ci życie.
źródło
Jednym z możliwych rozwiązań, których używam, jest użycie python3. Wydaje się, że rozwiązuje wiele problemów związanych z utf.
Przepraszam za późną odpowiedź, ale może to pomóc ludziom w przyszłości.
Na przykład,
źródło