zoukankan      html  css  js  c++  java
  • JsonPath教程

    类似于XPath在xml文档中的定位,JsonPath表达式通常是用来路径检索或设置Json的。其表达式可以接受“dot–notation”和“bracket–notation”格式,例如(.store.book[0].title、)[‘store’][‘book’][0][‘title’]

    2. 操作符

    符号 描述
    $ 查询的根节点对象,用于表示一个json数据,可以是数组或对象
    @ 过滤器断言(filter predicate)处理的当前节点对象,类似于java中的this字段
    * 通配符,可以表示一个名字或数字
    .. 可以理解为递归搜索,Deep scan. Available anywhere a name is required.
    . 表示一个子节点
    [‘’ (, ‘’)] 表示一个或多个子节点
    [ (, )] 表示一个或多个数组下标
    [start:end] 数组片段,区间为[start,end),不包含end
    [?()] 过滤器表达式,表达式结果必须是boolean

    3. 函数

    可以在JsonPath表达式执行后进行调用,其输入值为表达式的结果。

    名称 描述 输出
    min() 获取数值类型数组的最小值 Double
    max() 获取数值类型数组的最大值 Double
    avg() 获取数值类型数组的平均值 Double
    stddev() 获取数值类型数组的标准差 Double
    length() 获取数值类型数组的长度 Integer

    4. 过滤器

    过滤器是用于过滤数组的逻辑表达式,一个通常的表达式形如:[?(@.age > 18)],可以通过逻辑表达式&&或||组合多个过滤器表达式,例如[?(@.price < 10 && @.category == ‘fiction’)],字符串必须用单引号或双引号包围,例如[?(@.color == ‘blue’)] or [?(@.color == “blue”)]。

    操作符 描述
    == 等于符号,但数字1不等于字符1(note that 1 is not equal to ‘1’)
    != 不等于符号
    < 小于符号
    <= 小于等于符号
    > 大于符号
    >= 大于等于符号
    =~ 判断是否符合正则表达式,例如[?(@.name =~ /foo.*?/i)]
    in 所属符号,例如[?(@.size in [‘S’, ‘M’])]
    nin 排除符号
    size size of left (array or string) should match right
    empty 判空符号

    5. 示例

    {
        "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
            }
        },
        "expensive": 10
    }
    
    JsonPath表达式 结果
    $.store.book[*].author 或 $..author [ “Nigel Rees”, “Evelyn Waugh”, “Herman Melville”, “J. R. R. Tolkien” ]
    $.store.* 显示所有叶子节点值 [ [ { ”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 } ], { ”color” : “red”, ”price” : 19.95 } ]
    $.store..price [ 8.95, 12.99, 8.99, 22.99, 19.95 ]
    $..book[0,1] 或 $..book[:2] [ { ”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 } ]
    $..book[-2:] 获取最后两本书
    $..book[2:] [ { ”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 } ]
    $..book[?(@.isbn)] 所有具有isbn属性的书
    $.store.book[?(@.price < 10)] 所有价格小于10的书
    $..book[?(@.price <= $[‘expensive’])] 所有价格低于expensive字段的书
    $..book[?(@.author =~ /.*REES/i)] 所有符合正则表达式的书 [ { ”category” : “reference”, ”author” : “Nigel Rees”, ”title” : “Sayings of the Century”, ”price” : 8.95 } ]
    $..* 返回所有
    $..book.length() [ 4 ]

    测试请点击http://jsonpath.herokuapp.com/?path=$.store.book[*].author

  • 相关阅读:
    老外写的js闭包
    List<Object> 转为 List<MyClass>
    html 自定义属性
    js 中的算术运算
    System.Web.Mvc.Html 命名空间小计
    历时半年,发布最完整的代码生成器CodeBuilder最新版本
    CodeBuilder之Template接口
    CodeBuilder之Tool接口
    FaibClass.Data
    轻量的Json序列化
  • 原文地址:https://www.cnblogs.com/fuxiang-li/p/13910390.html
Copyright © 2011-2022 走看看