当前位置:
首页 > Python基础教程 >
-
python如何通过Json路径返回Json响应对应的值
这篇文章主要介绍了python如何通过Json路径返回Json响应对应的值问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
通过Json路径返回Json响应对应的值
最近做一个接口自动化项目时,需要根据Json响应体的路径来取出对应的值。
Json体有不同的层级结构,在Python中,类似于字典包数组或数组包字典的组合。
那知道了Json值的路径,怎么去拿到值呢。
话不多说,上代码
class PathValue:
def __init__(self, json_res, value_path):
"""
通过json路径找到需要的值,并存入一个全局字典
:param json_res: json响应
:param value_path: 取值路径
"""
self.json_res = json_res
self.value_path = value_path
def path_value_dic(self):
"""
如果存在多个值,使用,分隔value_path
:return:
"""
l_path = self.value_path.split(",")
for path in l_path:
self.json_path_value(self.json_res, path)
def json_path_value(self, d, s):
"""
根据传入的json路径从响应中取值,存入dic,主要运用了递归函数
:param d: 响应Json
:param s: Json路径
:return: 存入值的字典dic
"""
pahts = s.split(".")
if len(pahts) == 1:
dic[pahts[0]] = d[pahts[0]]
return
for p in pahts:
if p.isnumeric():
a = d[int(p)]
return self.json_path_value(a, '.'.join(pahts[1:]))
a = d[p]
return self.json_path_value(a, '.'.join(pahts[1:]))
if __name__ == '__main__':
dic = {}
d1 = {
"page": 1,
"total": 919,
"items": [
{
"csku": "1099688",
"rsku": "6992044",
}
],
}
s_path = 'items.0.csku,items.0.rsku'
# s_path = 'items.0.csku'
p = PathValue(d1, s_path)
p.path_value_dic()
print(dic)
以上代码,直接跑,可将需要取的值存入一个字典。
具体想怎么存怎么使用,就各自发挥了~
Python:返回json数据
安装json库
pip install json
conda install json
在Python中,你可以使用内置的json模块来返回一个JSON数据。以下是一个简单的例子:
示例
import json
def get_json():
data = {
"name": "John",
"age": 30,
"city": "New York"
}
return json.dumps(data)
# 调用函数并打印返回的JSON数据
print(get_json())
在这个例子中,首先导入了json模块。
然后定义了一个名为get_json的函数,该函数返回一个字典。
我们使用json.dumps()函数将这个字典转换为一个JSON字符串,然后返回这个字符串。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持
原文链接:https://blog.csdn.net/qq_42831466/article/details/121828018
栏目列表
最新更新
vbscript基础篇 - vbs数组Array的定义与使用方
vbscript基础篇 - vbs变量定义与使用方法
vbs能调用的系统对象小结
vbscript网页模拟登录效果代码
VBScript 根据IE窗口的标题输出ESC
杀死指定进程名称的小VBS
通过vbs修改以点结尾的文件的属性为隐藏
查询电脑开关机时间的vbs代码
VBA中的Timer函数用法
ComboBox 控件的用法教程
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比