zoukankan      html  css  js  c++  java
  • JsonPath

    测试路径:http://jsonpath.herokuapp.com

    1. 介绍

    类似于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.
    .<name> 表示一个子节点
    [‘<name>’ (, ‘<name>’)] 表示一个或多个子节点
    [<number> (, <number>)] 表示一个或多个数组下标
    [start:end] 数组片段,区间为[start,end),不包含end
    [?(<expression>)] 过滤器表达式,表达式结果必须是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
    ]
  • 相关阅读:
    ARM汇编伪指令介绍.
    初识KITL
    c面试题
    Windows ce的体系结构和功能
    c宏定义的技巧总结
    Build in Windows Mobile
    关于wince注册表
    动态链接库(Dynamic Link Library)学习笔记
    WinCE驱动开发问题精华集锦
    OAL之系统时钟
  • 原文地址:https://www.cnblogs.com/xiaowenshu/p/10143461.html
Copyright © 2011-2022 走看看