python中jsonpath模块,解析多层嵌套的json数据
- jsonpath介绍
用来解析多层嵌套的json数据;JsonPath 是一种信息抽取类库,是从JSON文档中抽取指定信息的工具,提供多种语言实现版本,包括:Javascript, Python, PHP 和 Java。
使用方法如:
import jsonpath
res=jsonpath.jsonpath(dic_name,’KaTeX parse error: Expected 'EOF', got '#' at position 14: ..key_name') #̲嵌套n层也能取到所有key_n…”表示最外层的{},“…”表示模糊匹配,当传入不存在的key_name时,程序会返回false
-
JsonPath 对于 JSON 来说,相当于 XPath 对于 XML。
安装方法:pip install jsonpath 官方文档:http://goessner.net/articles/JsonPath
-
JsonPath与XPath语法对比:
Json结构清晰,可读性高,复杂度低,非常容易匹配,下表中对应了XPath的用法。
Xpath JSONPath 描述
4. 使用实例
d={
“error_code”: 0,
“stu_info”: [
{
“id”: 2059,
“name”: “小白”,
“sex”: “男”,
“age”: 28,
“addr”: “河南省济源市北海大道32号”,
“grade”: “天蝎座”,
“phone”: “18378309272”,
“gold”: 10896,
“info”:{
“card”:434345432,
“bank_name”:‘中国银行’
}
},
{
"id": 2067,
"name": "小黑",
"sex": "男",
"age": 28,
"addr": "河南省济源市北海大道32号",
"grade": "天蝎座",
"phone": "12345678915",
"gold": 100
}
]
}
res= d[“stu_info”][1][‘name’] #取某个学生姓名的原始方法:通过查找字典中的key以及list方法中的下标索引
print(res) #输出结果是:小黑
import jsonpath
res1=jsonpath.jsonpath(d,'KaTeX parse error: Expected 'EOF', got '#' at position 10: ..name') #̲嵌套n层也能取到所有学生姓名信…表示最外层的{},…表示模糊匹配
print(res1) #输出结果是list:[‘小白’, ‘小黑’]
res2= jsonpath.jsonpath(d,’$…bank_name’)
print(res2) #输出结果是list:[‘中国银行’]
res3=jsonpath.jsonpath(d,’$…name123’) #当传入不存在的key(name)时,返回False
print(res3) #输出结果是:False