使用demjson解决json解析不规范格式json串JSONDecodeError错误

Json在编程中是一种轻量级的文件格式,在本地开发或者web开发中使用较多。参考维基百科介绍如下:

JSONJavaScript Object Notation,JavaScript对象表示法,读作/ˈdʒeɪsən/)是一种由道格拉斯·克罗克福特构想和设计、轻量级的资料交换语言,该语言以易于让人阅读的文字为基础,用来传输由属性值或者序列性的值组成的数据对象。尽管JSON是JavaScript的一个子集,但JSON是独立于语言的文本格式,并且采用了类似于C语言家族的一些习惯。

JSON 数据格式与语言无关。即便它源自JavaScript,但目前很多编程语言都支持 JSON 格式数据的生成和解析。JSON 的官方 MIME 类型application/json,文件扩展名是 .json

在python应用中,一般将列表或者字典等数据保存为json格式的字符串形式,以便后续使用。

json

在python的包中,有json这个包,直接拿来用即可,已经安装好。

常用的命令就两个:

  • json.dumps / json.dump : 将 Python 对象编码成 JSON 字符串 / 编码成json格式文件
  • json.loads / json.load: 解码python json格式 / 加载python json格式文件

s与不带s的区别在于不带s的一般与文件打交道,带s的只是转换形式。

例如:

import json

d = {"hello": "world"}


d_s = json.dumps(d)  # '{"hello": "world"}'

fp = file('test_json.txt', 'w')
json.dump(d, fp)


d = json.loads(d_s)  # d: {"hello": "world"}
d = json.load(fp)

问题

今天写接口的时候遇到一个问题,json解析会报错

假设原始数据为:

d_s =  "{'姓名': '张', '性别': '男', '住址': "湖南省9", '身份证号': '4302211', '民族': '汉'}"

前端传过来的其中一个参数是这样的,address对应的value中含有一个, 直接用json解析会报错:

JSONDecodeError: Expecting value: line 1 column 51 

解决办法

  1. 使用re字符替换的方式进行替换,但是发现其它部位也存在, 无法区分开
  2. 找到json的扩展包demjson

Demjson是 python 的第三方模块库,可用于编码和解码 JSON 数据,包含了 JSONLint 的格式化及校验功能。

安装
pip install demjson
使用
  • demjson.decode: 将已编码的 JSON 字符串解码为 Python 对象
  • demjson.encode: 将 Python 对象编码成 JSON 字符串

该包功能相较于json而言具有格式化校验功能, 能够解决这种多出来的问题

import demjson

d_s =  "{'姓名': '张', '性别': '男', '住址': "湖南省9号", '身份证号': '4302211', '民族': '汉'}"

d = demjson.decode(d_s)  # d : {'姓名': '张', '性别': '男', '住址': "湖南省9号", '身份证号': '4302211', '民族': '汉'}


d = {'1': 1}
d_s = demjson.encode(d)  #d_s : '{"1": 1}'

类似的还有其他不规则的格式:

"{x:1, y:2, z:3}"  - > {x:1, y:2, z:3}

"{'x':1, 'y':2, 'z':3}"  -> {'x':1, 'y':2, 'z':3}

'{"x":1, "y":2, "z":3}' -> {"x":1, "y":2, "z":3}

可以解决上述问题, 总的来说:

  • 遇到问题不要慌,多思考问题点在哪里,基于问题点去找解决方法
  • python的扩展包太多太强大,需要不断积累

参考

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

uncle_ll

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值