Skip to content

todototry/jsonpath

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 

Repository files navigation

JSON path selection

功能说明

  1. 支持任意层级的 key path 路径定位
  2. 支持json 中数组的自由筛选

使用说明

  1. 基础语法与标准的 json path 类似,但数组部分不一样, 数组的定位标识已经独立出来了,如下:

    nodeA.nodeB.[].nodeE.nodeF.[3-5].nodeG.[-6].nodeH.[1,5,7,9-]

  2. keypath路径定位:支持以自定义的间隔符隔离各个 node, 默认的 seperator 是'.' , 如下:

    nodeA.nodeB.nodeC

  3. json 数组的筛选:支持如下五种筛选方式

    1. 支持全量

      nodeA.nodeB.[]

      nodeA.nodeB.[*]

    2. 支持索引

      nodeA.nodeB.[3]

      nodeA.nodeB.[44]

    3. 支持半开截断

      nodeA.nodeB.[-4]

      nodeA.nodeB.[7-]

    4. 支持中间截断

      nodeA.nodeB.[3-5]

      nodeA.nodeB.[55-81]

    5. 支持组合:

      nodeA.nodeB.[-5,7-9,10,13,17-]

demo

详见代码中的 testcase, 可直接运行测试 运行结果如下:

[{'a111': [{'a1111': [11111, 2, 3]}, {'a1111': [11112, 2, 3]}, {'a1111': [11113, 2, 3]}]}, {'a111': [{'a1111': [22222, 2, 3]}, {'a1111': [222223, 2, 3]}, {'a1111': [222224, 2, 3]}]}]
--------1-------
[[{'a1111': [11111, 2, 3]}, {'a1111': [11112, 2, 3]}, {'a1111': [11113, 2, 3]}], [{'a1111': [22222, 2, 3]}, {'a1111': [222223, 2, 3]}, {'a1111': [222224, 2, 3]}]]
-------2--------
[[[11111, 2, 3], [11112, 2, 3], [11113, 2, 3]], [[22222, 2, 3], [222223, 2, 3], [222224, 2, 3]]]
-------3--------
[[11111, 2, 3], [11112, 2, 3], [11113, 2, 3]]
-------4--------
[[11111, 2, 3], [11112, 2, 3], [11113, 2, 3]]
-------5--------
[11111, 2, 3]
--------6-------
([0, 1, 2, 3, 4, 5, 7, 9, 10, 12, 13, 14, 15], True)
--------7-------

About

a python implementation of json path.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages