zoukankan      html  css  js  c++  java
  • JSONPATH使用方法

    如下的json:
    
    { "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,
            "isbn": "0-553-21311-3"
          }
        ],
        "bicycle": {
          "color": "red",
          "price": 19.95
        }
      }
    }
    

      

    private static void jsonPathTest() {
        JSONObject json = jsonTest();//调用自定义的jsonTest()方法获得json对象,生成上面的json
         
        //输出book[0]的author值
        String author = JsonPath.read(json, "$.store.book[0].author");
         
        //输出全部author的值,使用Iterator迭代
        List<String> authors = JsonPath.read(json, "$.store.book[*].author");
         
        //输出book[*]中category == 'reference'的book
        List<Object> books = JsonPath.read(json, "$.store.book[?(@.category == 'reference')]");               
         
        //输出book[*]中price>10的book
        List<Object> books = JsonPath.read(json, "$.store.book[?(@.price>10)]");
         
        //输出book[*]中含有isbn元素的book
        List<Object> books = JsonPath.read(json, "$.store.book[?(@.isbn)]");
         
        //输出该json中所有price的值
        List<Double> prices = JsonPath.read(json, "$..price");
         
        //可以提前编辑一个路径,并多次使用它
        JsonPath path = JsonPath.compile("$.store.book[*]"); 
        List<Object> books = path.read(json); 
    }
    

      

    语法:

    JsonPath

    描述

    $

    根节点

    @

    当前节点

    .or[]

    子节点

    ..

    选择所有符合条件的节点

    *

    所有节点

    []

    迭代器标示,如数组下标

    [,]

    支持迭代器中做多选

    [start:end:step]

    数组切片运算符

    ?()

    支持过滤操作

    ()

    支持表达式计算

    原文地址:http://www.cnblogs.com/weilunhui/p/3857366.html

  • 相关阅读:
    整理SVN代码-->正式环境的代码
    业务(1)
    在一个项目中跨领域调用接口的的实现
    一个java文件编译之后会产生多个class文件
    shutil模块
    shevle模块
    confiparser模块
    sys模块
    subprocess模块
    【ADO.NET】3、从TXT中导入数据到数据库
  • 原文地址:https://www.cnblogs.com/soundcode/p/9012518.html
Copyright © 2011-2022 走看看