• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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 -*-
    import socket
    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)
     print rec
     print rec.decode('unicode-escape').encode('utf-8')
     print rec.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解析

    import json
    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

    from demjson import decode # pip install demjson

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

    您可能感兴趣的文章:
    • 浅析python字符串前加r、f、u、l 的区别
    • Python判断字符串是否为空和null方法实例
    • python 工具 字符串转numpy浮点数组的实现
    • python不相等的两个字符串的 if 条件判断为True详解
    • python去除删除数据中\u0000\u0001等unicode字符串的代码
    • 关于Python字符串显示u...的解决方式
    • python str字符串转uuid实例
    上一篇:django中的*args 与 **kwargs使用介绍
    下一篇:python numpy.power()数组元素求n次方案例
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Python 处理带有 \u 的字符串操作 Python,处理,带有,的,字符串,