Python 处理带有 \u 的字符串操作
最近遇到一个头疼的问题,用socket接收到一个字符串
格式如下:
{“trade_status”:{“desc”:“\u30106\u3011-\u8d22\u52a1\u7ed3\u7b97\u5df2\u5b8c\u6210“}}/end/
其中含有一段含有\u的编码字串,怎么将其转化为汉字。
decode().encode(‘utf-8')不行,decode、encode半天搞不定,后来偶然发现,在decode时可以选则unicode-escape
代码如下:
#-*-coding:utf-8-*- importsocket if__name__=='__main__': sock=socket.socket(socket.AF_INET,socket.SOCK_STREAM) sock.connect(('192.168.6.63',10001)) sock.send('[{"action":"trade_status"}]') rec=sock.recv(1024) printrec printrec.decode('unicode-escape').encode('utf-8') printrec.decode('raw_unicode-escape').encode('utf-8') sock.close()
输出结果:
{"trade_status":{"desc":"\u30101\u3011-\u4ea4\u6613\u4e2d"}}/**end**/ {"trade_status":{"desc":"【1】-交易中"}}/**end**/ {"trade_status":{"desc":"【1】-交易中"}}/**end**/
补充:Python3解析【\u】和【\\u】字符
【\u】字符示例
a='\u5317\u4eac\u5e02' print(a)
北京市
b='\\u5317\\u4eac\\u5e02' print(b)
\u5317\u4eac\u5e02
json.loads解析
importjson a='\\u5317\\u4eac\\u5e02' b='"%s"'%a c=json.loads(b) print(a,b,c,sep='\n')
\u5317\u4eac\u5e02
“\u5317\u4eac\u5e02”
北京市
读取文件中\u字符
demjson
fromdemjsonimportdecode#pipinstalldemjson
以上为个人经验,希望能给大家一个参考,也希望大家多多支持毛票票。如有错误或未考虑完全的地方,望不吝赐教。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。