在對文件內容或字符串進行JSON反序列化(deserialize)時,由于原始內容編碼問題,可能需要對反序列化后的內容進行編碼處理(如將unicode對象轉換為str)。
在Python中,一種方式是先使用json.load或json.loads反序列化得到dict對象,然后對這個dict對象進行編碼處理。
但其實在json.load與json.loads中,有可選參數object_hook。通過使用此參數,可以對反序列化得到的dict直接進行處理,并使用處理后新的dict替代原dict返回。
使用方法為:
代碼如下:
d = json.loads(json_str, object_hook=_decode_dict)
附Shadowsocks中使用的_decode_dict與_decode_list:
代碼如下:
def _decode_list(data):
rv = []
for item in data:
if isinstance(item, unicode):
item = item.encode('utf-8')
elif isinstance(item, list):
item = _decode_list(item)
elif isinstance(item, dict):
item = _decode_dict(item)
rv.append(item)
return rv
def _decode_dict(data):
rv = {}
for key, value in data.iteritems():
if isinstance(key, unicode):
key = key.encode('utf-8')
if isinstance(value, unicode):
value = value.encode('utf-8')
elif isinstance(value, list):
value = _decode_list(value)
elif isinstance(value, dict):
value = _decode_dict(value)
rv[key] = value
return rv
參考:
1.https://docs.python.org/2/library/json.html
2.https://github.com/clowwindy/shadowsocks/blob/master/shadowsocks/utils.py
新聞熱點
疑難解答