一篇长文带你在python里玩转Json数据

“name”: “Marty”,

“age”: null

}

]

}

}

以上图为例,再多说几句Json格式的特点

  • 对象通过键值对表现;

  • 键通过双引号包裹,后面跟冒号“:”,然后跟该键的值;

  • 值可以是字符串、数字、数组等数据类型;

  • 对象与对象之间用逗号隔开;

  • “{}”用来表达对象;

  • “[]”用来表达数组;

Python中的Json模块


Python中也自带了Json模块,其中json.dumps()、json.loads()较为常用。

  • json.dumps() 是将 python 对象转化为 json。

  • json.loads() 是将 json 转化为 python 对象。

在这里插入图片描述

#json.dumps(),json.loads()

import json

dict_data = {“a”: 1, “b”: 2}

将dict格式数据转换成json格式字符串

dump_data = json.dumps(dict_data)

将json格式字符串转换成对应的python值

load_data = json.loads(dump_data)

打印转换结果

print(type(dict_data),dict_data)

print(type(dump_data),dump_data)

print(type(load_data),load_data)

运行结果:

<class ‘dict’> {‘a’: 1, ‘b’: 2}

<class ‘str’> {“a”: 1, “b”: 2}

<class ‘dict’> {‘a’: 1, ‘b’: 2}

在例子中一开始的变量 dict_data 是一个字典,json.dumps() 后,将dict格式数据转换成json格式字符串。这时候虽然都是{‘a’: 1, ‘b’: 2},但是格式却前后不一样。随后又通过 json.loads(),重新将json格式字符串转换成字典。

在线解析Json


在实际应用中,要提取json数据,就要了解返回json数据的结构。

可是Json格式的数据往往是这样的。

在这里插入图片描述

在这里插入图片描述

大家别担心,我们可以将数据复制到一些json插件或在线解析!

比如这个插件是小五常用的:

在这里插入图片描述

此时再打开刚才的网址

在这里插入图片描述

是不是清晰了很多呢?

如果用python来获取里面的数据怎么做的?

先利用 json.loads() 来将 Json 转成字典,再用 get() 函数直到得到我们想要的list 对象,那么对于 list 里面的数据我们用个 for 循环就行啦~

额,有点绕。

在这里插入图片描述

还是文章一开始的例子,我们想获取其中所有狗狗的名字:

{

“animals”: {

“dog”: [

{

“name”: “Rufus”,

“age”:15

},

{

“name”: “Marty”,

“age”: null

}

]

}

}

我们可以这样做:

load_data = json.loads(dump_data)

data = load_data.get(“animals”).get(“dog”)

result1 = []

for i in data:

result1.append(i.get(“name”))

print(result1)

运行结果:

[‘Rufus’, ‘Marty’]

这样确实可以获得我们想要的结果。

PS:类似的在线解析网站也有很多

JsonPath


不知道大家还记不记得,在一开始介绍Json时,我提到了它相对于XML来说,更加的轻量级,更方便解析。

既然 XML 人家都有 XPATH ,那么Json有没有类似的工具呢?

在这里插入图片描述

JsonPath 是一种信息抽取类库,是从Json文档中抽取指定信息的工具。

JsonPath 对于 Json 来说,相当于 XPATH 对于 XML。

Json结构清晰,可读性高,复杂度低,非常容易匹配,下表是JsonPath的用法。

在这里插入图片描述

在这里插入图片描述

没错,还是这个例子,我们这次尝试用JsonPath获取其中所有狗狗的名字:

{

“animals”: {

“dog”: [

{

“name”: “Rufus”,

“age”:15

},

{

“name”: “Marty”,

“age”: null

}

]

}

}

我们可以这样做:

load_data = json.loads(dump_data)

jobs=load_data[‘animals’][‘dog’]

result2 = []

for i in data:

从根节点开始,匹配name节点

result2.append(jsonpath.jsonpath(i,‘$…name’)[0])

print(result2)

其中 $…name 代表从根节点开始,匹配name节点

运行结果:

现在能在网上找到很多很多的学习资源,有免费的也有收费的,当我拿到1套比较全的学习资源之前,我并没着急去看第1节,我而是去审视这套资源是否值得学习,有时候也会去问一些学长的意见,如果可以之后,我会对这套学习资源做1个学习计划,我的学习计划主要包括规划图和学习进度表。

分享给大家这份我薅到的免费视频资料,质量还不错,大家可以跟着学习

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里无偿获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值