python中jsonpath的使用小结

 更新时间:2024年03月20日 09:13:28   作者:hjc_042043  
JsonPath是一种信息抽取类库,是从JSON文档中抽取指定信息的工具,提供多种语言实现版本,本文主要介绍了python中jsonpath的使用小结,具有一定的参考价值,感兴趣的可以了解一下

介绍

JSONPath能在复杂的JSON数据中 查找和提取所需的信息,它是一种功能强大的查询语言,可以通过简单的表达式来快速准确地定位和提取JSON数据。本文将介绍JSONPath的基本语法和用法,并为您展示如何封装和使用JSONPath方法来处理和操作JSON数据。
JSONPath类似于XPath提供了一种更简洁、灵活和高效的方式来查询、定位和提取JSON数据中的内容

安装

pip install jsonpath

语法

from jsonpath import jsonpath
res = jsonpath(dict,'jsonpath语法规则字符串')

语法规则

JsonPath描述
$根节点元素,最外层的大括号
@当前节点元素
. 或 []绝对路径,取子节点元素
相对路径,内部的任意位置,选择符合条件的子孙节点元素
*匹配所有元素节点
[]迭代器提示(可以在里边做简单的迭代操作,如数组下标,根据内容筛选)
[,]支持迭代器中做多选
?()支持过滤操作
()支持表达式计算

举例说明

获取书架上的书进行操作

  • 数据结构:
book_dict = {
    "store":{
        "book":[
            {
                "name": "java 核心编程1",
                "price": "65",
                "isbn": "IS002598934",
                "author" : "周立新"
            },
            {
                "name": "java 核心编程2",
                "price": "64",
                "isbn": "IS876430456",
                "author": "周立新"
            },
            {
                "name" : "java 编程思想",
                "price": "120",
                "isbn": "IS256709873",
                "author": "Bruce Eckel"
            },
            {
                "name" : "RabbitMq 实战指南",
                "price": "79",
                "isbn": "IS987623450",
                "author": "朱忠华"
            },
            {
                "name" : "图解 TCP/IP",
                "price": "69",
                "isbn": "IS9787354679",
                "author": "竹下隆史"
            }
        ]
    }
}
  • 结构解析例子
JsonPath结果
$.store.book[*].authorstore 中的所有的 book的作者
$…store.*所有的书籍
$.store…pricestore 中的所有的内容的价格
$…book[2]第三本书
$…book[(@.length-1)] 或 $…book[-1:]最后一本书
$…book[0,1] 或 $…book[:2]前两本书
$…book[?(@.isbn)]获取有 isbn 的所有数
$…book[?(@.price<100)]获取价格<100的所有的书
$…*获取所有的数据

在 python 中使用

如下代码都用单元测试来举例,具体代码链接:去这里

  • 设置测试结构
def setUp(self):
  """
  前置设置
  @return:
  """
  self.book_dict = {
      "store": {
          "book": [
              {
                  "name": "java 核心编程1",
                  "price": 65,
                  "isbn": "IS002598934",
                  "author": "周立新"
              },
              {
                  "name": "java 核心编程2",
                  "price": 64,
                  "isbn": "IS876430456",
                  "author": "周立新"
              },
              {
                  "name": "java 编程思想",
                  "price": 120,
                  "isbn": "IS256709873",
                  "author": "Bruce Eckel"
              },
              {
                  "name": "RabbitMq 实战指南",
                  "price": 79,
                  "isbn": "IS987623450",
                  "author": "朱忠华"
              },
              {
                  "name": "图解 TCP/IP",
                  "price": 69,
                  "isbn": "IS9787354679",
                  "author": "竹下隆史"
              }
          ]
      }
  }
  pass

获取所有结构

def test_all(self):
    """
    获取所有的结构
    @return:
    """
    dict_data = jsonpath(self.book_dict, '$..*')
    print("查看dict_data支持的属性和方法:", dir(dict_data))

    try:
        for item in dict_data[0]['book']:
            # 美化打印
            pprint(item)
    except Exception as e:
        print(e)
        pass

所有子节点的作者

def test_sub_author(self):
    """
    获取所有子节点的作者
    @return:
    """
    all_author = jsonpath(self.book_dict, '$.store.book[*].author')
    print(all_author)
    pass

获取所有子孙节点

def test_sub_all(self):
    """
    获取所有子孙节点
    @return:
    """
    sub_all = jsonpath(self.book_dict, '$..store.*')
    print(sub_all)
    pass

获取所有价格

def test_price_all(self):
    """
    获取子节点的所有价格
    @return:
    """
    price_all = jsonpath(self.book_dict, '$..price')
    print("所有的价格:", price_all)

    price_sum = sum([int(price) for price in price_all])
    print(f"价格之和:{price_sum}")
    pass

取出第三本书的所有信息

 def test_book_item(self):
     """
     取出第三本书的所有信息
     @return:
     """
     book_item = jsonpath(self.book_dict, '$..book[2]')
     print(book_item)
     pass

取出价格大于70块的所有书本

def test_book_filter(self):
    book_count = jsonpath(self.book_dict, '$..book[?(@.price>70)]')
    print(book_count)

从mongodb 中取数据的示例

遇到复杂的结构可以使用 pprint()来美化打印

def test_mongo_data(self):
    """
    获取mongo中的复杂结构的数据
    @return:
    """
    dict_data = MongoPool().project_8.coffer_check_data.find_one({"_id": "629dbfe615e74466831b5ce2"})
    # 美化打印
    pprint(dict_data)
    change_list = jsonpath(dict_data, '$..change')
    print("获取某一个字字段的列表:", change_list)
    pass

效果:

在这里插入图片描述

到此这篇关于python中jsonpath的使用小结的文章就介绍到这了,更多相关python jsonpath使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python查找大文件的实用脚本分享

    Python查找大文件的实用脚本分享

    这篇文章主要为大家分享一个利用Python查找大文件的实用脚本,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-11-11
  • Python实现在PowerPoint演示文稿中添加漏斗图

    Python实现在PowerPoint演示文稿中添加漏斗图

    漏斗图是一种常用的数据可视化工具,本文将介绍如何使用 Python 和 Spire.Presentation for Python 库在 PowerPoint 演示文稿中创建专业的漏斗图,文中的示例代码讲解详细,有需要的小伙伴可以了解下
    2026-06-06
  • 在Python中分别打印列表中的每一个元素方法

    在Python中分别打印列表中的每一个元素方法

    今天小编就为大家分享一篇在Python中分别打印列表中的每一个元素方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-11-11
  • python flask解析json数据不完整的解决方法

    python flask解析json数据不完整的解决方法

    这篇文章主要介绍了python flask解析json数据不完整的解决方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-05-05
  • Python实现批量读取word中表格信息的方法

    Python实现批量读取word中表格信息的方法

    这篇文章主要介绍了Python实现批量读取word中表格信息的方法,可实现针对word文档的读取功能,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • Python利用PyMobileDevice3控制iOS设备的完整教程

    Python利用PyMobileDevice3控制iOS设备的完整教程

    PyMobileDevice3是一个纯Python 3实现的iOS设备控制工具库,为开发者和技术爱好者提供了强大的iOS设备管理能力,所以本文给大家介绍了Python利用PyMobileDevice3控制iOS设备的完整教程,需要的朋友可以参考下
    2025-12-12
  • 数据驱动测试DDT之Selenium读取Excel文件

    数据驱动测试DDT之Selenium读取Excel文件

    这篇文章主要为大家介绍了数据驱动测试DDT之Selenium读取Excel文件,
    2021-11-11
  • python向企业微信发送文字和图片消息的示例

    python向企业微信发送文字和图片消息的示例

    这篇文章主要介绍了python向企业微信发送文字和图片消息的示例,帮助大家更好的理解和使用python,感兴趣的朋友可以了解下
    2020-09-09
  • Pandas搭配lambda组合使用详解

    Pandas搭配lambda组合使用详解

    大家好,在之前文章中,我们介绍了很多 Python 用法。喜欢的朋友可以看一下历史文章。今天我给大家讲讲lambda与pandas模块配合使用方法,熟练掌握可以极大地提高数据分析与挖掘的效率
    2022-01-01
  • Python 中的结构模式匹配及重要性

    Python 中的结构模式匹配及重要性

    这篇文章主要介绍了Python 中的结构模式匹配,本篇文章介绍结构模式匹配及其在 Python 中的重要性,它还使用不同的模式来演示如何使用 match … case 语句,需要的朋友可以参考下
    2023-06-06

最新评论