Python中使用jsonpath进行模糊匹配
温馨提示:这篇文章已超过377天没有更新,请注意相关的内容是否还可用!
目录
(图片来源网络,侵删)
1.背景
2.问题
3.参考资料
1.背景
在自动化测试脚本中,jsonpath确实是一个挺好用的小组件。网上已经有很多关于其基本使用方法的文档,这里就不再啰嗦了。本文想要提出的一个疑问是:如何在不使用正则表达式的前提下,通过jsonpath自己的语法完成模糊匹配的操作呢?类似SQL中的LIKE "%test%"
2.问题
以通用的JSON对象为例:
data = { "store": {
"book": [
{ "category": "reference",
"author": "Nigel Rees",
"title": "Sayings of the Century",
"price": 8.95
},
{ "category": "fiction",
"author": "Evelyn Waugh",
"title": "Sword of Honour",
"price": 12.99
},
{ "category": "fiction",
"author": "Herman Melville",
"title": "Moby Dick",
"isbn": "0-553-21311-3",
"price": 8.99
},
{ "category": "fiction",
"author": "J. R. R. Tolkien",
"title": "The Lord of the Rings",
"isbn": "0-395-19395-8",
"price": 22.99
}
],
"bicycle": {
"color": "red",
"price": 19.95
}
}
}
目标:提取出书记标题中含有"ord"字段的内容。即,
{ "category": "fiction",
"author": "J. R. R. Tolkien",
"title": "The Lord of the Rings",
"isbn": "0-395-19395-8",
"price": 22.99
}
{ "category": "fiction",
"author": "Evelyn Waugh",
"title": "Sword of Honour",
"price": 12.99
}
解决方案一:
$.store.book[?(@ && @.title && /ord/.test(@.title))]
通过一些jsonpath在线解析工具,上面的这种提取方式的确可以提取到我们需要的内容。但当我们放到python代码中。如下方所示,就不能生效了。怀疑是因为这里有特殊字符"/"。可一直也没有找到如何转义
result = jsonpath.jsonpath(data, f"$.store.book[?(@ && @.title && /ord/.test(@.title))")
解决方案二:
$..book[?(@.author =~ /.*REES/i)]
这种方式和第一种一样,都含有一些特殊字符。在Python代码中就会失效。
笔者注意到,上述方式都是在import json这个库下去完成的,所以一直失效。
解决方案三:
导入库 from pyjsonpath import JsonPath,然后再采用类似方案二中的表达式即可。当然,下方的这种表达式也ok
result = JsonPath(data, "$.store.book[?(@.title =~ /.*?ord.*?/i)]").load()
3.参考资料
使用jsonpath进行字符串搜索 |
python-jsonpath解析_玉米丛里吃过亏的博客-CSDN博客_jsonpath python
Python3中JsonPath用法 - 漂泊的小虎 - 博客园
[SoapUI] JsonPath 语法 与 XPath 对比 - 开发者博
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!
