今日看点:使用Python处理json字符串中的非法双引号问题
这篇文章主要介绍了使用Python处理json字符串中的非法双引号问题,具有
脚本之家 2023-07-02 09:07:17
工作中数据清洗时遇到以下情况:
(资料图)
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()便不会报错了
在 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)
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
这篇文章主要介绍了使用Python处理json字符串中的非法双引号问题,具有
点击下方卡片关注“有书”,加⭐星标⭐不迷路文|桌子·主播|亚楠来源|
1、第3季主要讲吸血鬼祖先的。2、建议不要先看剧情。本文到此分享完毕
7月1日,首届河南航空植保嘉年华在郑州上街机场正式拉开序幕,据悉这是
豆来为大家解答以上的问题。罗斯柴尔德桃红香槟,桃红香槟这个很多人还
当前大家对于配额词语都是颇为感兴趣的,大家都想要了解一下配额词语,
1、您好!中等身材应该是mediumheight除此之外英语中亦有其他的表达方
1、很久以前,我一直梦想梦见自己最喜欢的明星,却一直未能实现这个梦
7月1日,韩国最大在野党共同民主党在韩国首尔市中心崇礼门举行大规模集
在庙镇合中村,田间地头处处都能看到刘炎燕忙碌的身影。自2021年接捧村
hello大家好,我是城乡经济网小晟来为大家解答以上问题,屈臣氏男士护
6月29日上午,漯河市郾城区人民法院党组书记、院长赵军黎带队前往李集
01:08北京日报客户端在中国共产党成立102周年之际,国家大剧院特别呈现
上海威士顿信息技术股份有限公司(以下简称“威士顿”)日前正式登陆深
来源:国防部发布6月24日至7月1日,中国人民解放军防务战略磋商代表团