使用Python处理json字符串中的非法双引号问题

作者:Nick_Spider 时间:2021-01-19 19:26:13 

Python处理json字符串中的非法双引号

工作中数据清洗时遇到以下情况:

a = '{"地区": "湖南", "描述": "精通软件开发、"数据挖掘"和分布式"}'

由于读取出的json字符串中包含有非法双引号,在使用json.loads()处理的时候报错

json.decoder.JSONDecodeError: Expecting ',' delimiter: line 1 column 29 (char 28)

写了大半个小时的正则都无法解决

后来使用如下方法解决了,一并把json字符串中的换行符、分隔符和双引号都转义了

def deal_json_invaild(data):
    data = data.replace("\n", "\\n").replace("\r", "\\r").replace("\n\r", "\\n\\r") \
        .replace("\r\n", "\\r\\n") \
        .replace("\t", "\\t")
    data = data.replace('": "', '&&testPassword&&')\
        .replace('", "', "$$testPassword$$")\
        .replace('{"', "@@testPassword@@")\
        .replace('"}', "**testPassword**")
    print(data)

    data = data.replace('"', r'\"')\
        .replace('&&testPassword&&', '": "').replace('$$testPassword$$', '", "').replace('@@testPassword@@', '{"').replace('**testPassword**', '"}')
    print(data)
    return data

测试如下:

a = deal_json_invaild(a)
json_data = json.loads(a)

> {"地区": "湖南", "描述": "精通软件开发、\"数据挖掘\"和分布式"}

此时转使用json.loads()便不会报错了

Python json单、双引号问题

在 python3 里,一个json是一个字典,形如 {"a":15}

json转换成字符串的话

那么,如果你要将它转换成字符串,也许你用的是str({"a":15}),这样转出来的,可能是是s= "{'a':'15'}",也就是说,里面的kv是单引号的。这个字符串,传到其他地方,再用json.loads(s)的时候会出错,json不支持单引号。

所以,假如你想把一个json结构,转成字符串,传递给远处,然后再重新解析成json结构,应该这样:

s = json.dumps({"a":15})

然后,把数据传到远端,然后再解析回来:

d = json.loads(s)

这样就不会出错了。

也支持列表,能一次性传多个结构

s = json.dumps([{"a":15}, {"b":20}])

然后,把数据传到远端,然后再解析回来:

d = json.loads(s)

来源:https://blog.csdn.net/weixin_39198406/article/details/81709397

标签:Python,json,字符串,非法,双引号
0
投稿

猜你喜欢

  • asp函数解决SQL注入漏洞

    2008-10-12 19:53:00
  • Oracle中的translate函数和replace函数的用法详解

    2024-01-16 15:46:29
  • 对网站内嵌gradio应用的输入输出做审核实现详解

    2023-07-22 08:22:05
  • Yii使用find findAll查找出指定字段的实现方法

    2024-05-03 15:13:37
  • Win10系统提示“Python 0x80070643安装时发生严重错误”怎么办?

    2023-06-13 06:50:25
  • MySQL 1303错误的解决方法(navicat)

    2024-01-25 21:24:42
  • pytorch DistributedDataParallel 多卡训练结果变差的解决方案

    2021-09-24 14:31:43
  • python实现学生信息管理系统(面向对象)

    2022-06-13 16:16:07
  • 客户端限制只能上传jpg格式图片的js代码

    2023-07-16 00:56:04
  • requests.gPython 用requests.get获取网页内容为空 ’ ’问题

    2021-12-06 08:52:31
  • Golang 函数执行时间统计装饰器的一个实现详解

    2024-05-09 09:46:22
  • JavaScript字典与集合详解

    2024-04-16 09:28:13
  • 使用Python可设置抽奖者权重的抽奖脚本代码

    2023-08-27 09:17:19
  • 使用django-guardian实现django-admin的行级权限控制的方法

    2022-01-13 04:58:25
  • mysql8.0.11 winx64安装配置方法图文教程(win10)

    2024-01-23 07:58:58
  • PHP编码转换函数 自动转换字符集支持数组转换

    2024-05-02 17:33:28
  • sqlserver 复制表 复制数据库存储过程的方法

    2024-01-21 17:01:00
  • PHP中非常有用却鲜有人知的函数集锦

    2023-11-24 14:29:47
  • WEB2.0网页制作标准教程(9)第一个CSS布局实例

    2008-02-19 19:05:00
  • django queryset 去重 .distinct()说明

    2022-10-12 01:01:00
  • asp之家 网络编程 m.aspxhome.com