В настоящее время у меня есть этот словарь, напечатанный с использованием 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}
Когда я это сделаю:
import json
d = (my dictionary above)
jsonarray = json.dumps(d)
Я получаю такую ошибку: 'utf8' codec can't decode byte 0xff in position 0: invalid start byte
python
python-2.7
HyperDevil
источник
источник
\xff
Ответы:
Если вас устраивают непечатаемые символы в вашем json, добавьте
ensure_ascii=False
вdumps
call.источник
indent=n
к параметрам красивую печать, гдеn
количество пробелов для отступаsure_ascii = False действительно только переносит проблему на этап декодирования:
В конечном итоге вы не можете хранить необработанные байты в документе JSON, поэтому вы захотите использовать некоторые средства однозначного кодирования последовательности произвольных байтов в виде строки ASCII, например base64.
источник
b64encode
. Например, для строки в 256 символовs = ''.join(chr(i) for i in xrange(256))
,len(json.dumps(b64encode(s))) == 346
противlen(json.dumps(s.decode('latin1'))) == 1045
.Если вы используете Python 2, не забудьте добавить комментарий кодировки файла UTF-8 в первую строку вашего скрипта.
Это устранит некоторые проблемы с Unicode и упростит вам жизнь.
источник
Одно из возможных решений, которое я использую, - использовать python3. Кажется, решает многие проблемы с UTF.
Извините за поздний ответ, но он может помочь людям в будущем.
Например,
источник