- 支持任意层级的 key path 路径定位
- 支持json 中数组的自由筛选
-
基础语法与标准的 json path 类似,但数组部分不一样, 数组的定位标识已经独立出来了,如下:
nodeA.nodeB.[].nodeE.nodeF.[3-5].nodeG.[-6].nodeH.[1,5,7,9-]
-
keypath路径定位:支持以自定义的间隔符隔离各个 node, 默认的 seperator 是'.' , 如下:
nodeA.nodeB.nodeC
-
json 数组的筛选:支持如下五种筛选方式
-
支持全量
nodeA.nodeB.[]
nodeA.nodeB.[*]
-
支持索引
nodeA.nodeB.[3]
nodeA.nodeB.[44]
-
支持半开截断
nodeA.nodeB.[-4]
nodeA.nodeB.[7-]
-
支持中间截断
nodeA.nodeB.[3-5]
nodeA.nodeB.[55-81]
-
支持组合:
nodeA.nodeB.[-5,7-9,10,13,17-]
-
详见代码中的 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-------