jmespath库解析json

在测试过程中,经常会去JSON中的某个值,jmespath可以是除了jsonpath的另外一种选择.
下面通过几个例子来说明jmespath在python的使用

jmespath python安装

非常简单直接pip,

pip install jmespath

查询一个key值

source={"a": "foo", "b": "bar", "c": "baz"}
result = jmespath.search("a",source)
print(result)

subexpression

类似于jsonpath,通过.来表示路径的层级

source_1={"a": {"b": {"c": {"d": "value"}}}}
sub_result = jmespath.search("a.b.c",source_1)
print(sub_result)

这个例子的结果为:{'d': 'value'}

index expressions

index expression主要使用在数组上

source_2 = ["a", "b", "c", "d", "e", "f"]
index_result = jmespath.search("[1]",source_2)
print(index_result)

这个例子的结果为:b

多个表达式综合使用

以上几种表达式可以合起来一期使用:

composite_exp = "a.b.c[0].d[1][0]"
source_3= {"a": {
"b": {
"c": [
{"d": [0, [1, 2]]},
{"d": [3, 4]}
]
}
}}

composite_result = jmespath.search(composite_exp,source_3)
print(composite_result)

这个例子的结果为1

Slicing 切片

slicing 和python本身的slicing比较像,

source_4=[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
slicing_exp = "[0:5]"
slicing_result = jmespath.search(slicing_exp,source_4)
print(slicing_result)

这个例子的结果为: [0, 1, 2, 3, 4]

slicing实际上和python自己的机制基本一样,同样这个也是主要给数组使用.
有一点需要记住,基本的slicing的格式其实是: [start:stop:step]


基本上把网站上例子试了一下,总体感觉功能是相当强大.

# {"data": {
    #     "yesterday": {"date": "17日星期四", "high": "高温 31℃", "fx": "东南风", "low": "低温 22℃", "fl": "<![CDATA[<3级]]>",
    #                   "type": "多云"},
    #     "city": "北京",
    # "aqi": "91", # "forecast": [ # {"date": "18日星期五", "high": "高温 28℃", "fengli": "<![CDATA[<3级]]>", "low": "低温 22℃", "fengxiang": "东北风", # "type": "多云"}, # {"date": "19日星期六", "high": "高温 29℃", "fengli": "<![CDATA[<3级]]>", "low": "低温 22℃", "fengxiang": "东风", # "type": "雷阵雨"}, # {"date": "20日星期天", "high": "高温 29℃", "fengli": "<![CDATA[<3级]]>", "low": "低温 23℃", "fengxiang": "东南风", # "type": "阴"}, # {"date": "21日星期一", "high": "高温 30℃", "fengli": "<![CDATA[<3级]]>", "low": "低温 24℃", "fengxiang": "西南风", # "type": "晴"}, # {"date": "22日星期二", "high": "高温 29℃", "fengli": "<![CDATA[<3级]]>", "low": "低温 24℃", "fengxiang": "北风", # "type": "雷阵雨"} # ], # "ganmao": "各项气象条件适宜,无明显降温过程,发生感冒机率较低。", "wendu": "25" # }, # "status": 1000, # "desc": "OK"} j = JMESPathExtractor() j_1 = j.extract(query='data.forecast[1].date', body=res.text) j_2 = j.extract(query='data.ganmao', body=res.text) print(j_1, j_2) # 结果: # 19日星期六 各项气象条件适宜,无明显降温过程,发生感冒机率较低。

转载于:https://www.cnblogs.com/xiaohuhu/p/9605357.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python中的requests可以用来发送HTTP请求,并且可以解析返回的JSON数据。 使用requests发送HTTP请求时,可以通过设置请求头、请求参数、请求体等来定制请求。发送请求后,可以通过response对象获取返回的数据,其中包括JSON数据。 解析JSON数据可以使用response对象的json()方法,该方法会将返回的JSON数据转换为Python中的字典或列表类型。例如: ``` import requests response = requests.get('http://example.com/api/data') data = response.json() print(data) ``` 以上代码会发送一个GET请求到http://example.com/api/data,并将返回的JSON数据解析为Python中的字典或列表类型,并打印出来。 ### 回答2: Python中的requests是用来发送HTTP请求的。而解析json数据是其中一个很常见的功能,也很容易用requests去实现。下面是关于requests解析json的一些讲解。 首先,如果已经获取到了json数据,可以将其直接解析为Python中的字典(dictionary)类型。这可以通过requests返回的`response`对象的`json()`方法来实现。具体的操作流程可以如下: ```python import requests response = requests.get('http://example.com/api/data.json') data_dict = response.json() # 将response中的json数据转换为Python字典 ``` 这里得到的`data_dict`变量就是Python的字典,我们可以对它进行操作,如获取其中的值、添加新的键值对等等。 此外,在请求时也可以将`json`参数传给`requests`,用于发送包含json数据的请求。这可以通过`post`方法和`put`方法的`json`参数来实现。具体的用法可以看下面代码: ```python import requests data_dict = {'key1': 'value1', 'key2': 'value2'} response = requests.post('http://example.com/api/data.json', json=data_dict) ``` 这就向`http://example.com/api/data.json`发送了一个POST请求,并在请求体中附带上了`data_dict`字典。在服务器端接收该请求时,可以使用相应的(如Flask、Django等)来解析这个包含json数据的请求。 总之,requests的`json()`方法和`post/put`方法的`json`参数都很方便实用。如果想要了解更多的requests用法,可以访问[官方文档](https://requests.readthedocs.io/en/latest/)。 ### 回答3: Python中的Requests是一种HTTP,它可以用来处理与HTTP相关的请求和响应。Requests中提供了从web服务器获取JSON数据的方法。通过使用Requests,可以轻松地从web服务器获取JSON响应并解析JSON数据。 许多web API都提供了JSON格式的响应,因此,使用Requests从API获取JSON响应时,可以使用以下代码: ``` import requests url = 'http://example.com/api/get_data' response = requests.get(url) json_data = response.json() ``` 在上面的例子中,我们首先将API URL存储在变量url 中,然后使用 get() 方法获取响应,最后通过 response.json() 方法将响应转换为JSON格式的数据。将JSON响应转换为Python字典或列表后,我们可以对其进行操作,提取有用的数据。 对于更复杂的JSON响应,可以使用Python中的json模块解析JSON数据。下面是一个例子,展示了如何使用Requestsjson模块从API获取JSON响应并解析JSON数据: ``` import requests import json url = 'http://example.com/api/get_data' response = requests.get(url) json_data = json.loads(response.text) # 处理json_data字典中的数据 ``` 在上面的代码中,我们首先使用requests获取API响应,然后使用json.loads()方法将响应文本解析为Python字典或列表。最后,我们可以对这个字典或列表进行操作,提取有用的数据。 总的来说,使用Requests解析JSON数据是非常简单的,只需要使用response.json()方法或json.loads()方法即可将响应转换为Python字典或列表,然后可以通过对这个字典或列表进行操作来提取有用的数据。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值