• JsonPath的用法


    有时候需要从json里面提取相关数据,必须得用到如何提取信息的知识,下面来写一下

    语法格式

    JsonPath

    描述

    $

    根节点

    @

    当前节点

    .or[]

    子节点

    ..

    选择所有符合条件的节点

    *

    所有节点

    []

    迭代器标示,如数组下标

    [,]

    支持迭代器中做多选

    [start:end:step]

    数组切片运算符

    ?()

    支持过滤操作

    ()

    支持表达式计算

    json格式的数据:

     1 { "store": {
     2     "book": [ 
     3       { "category": "reference",
     4         "author": "Nigel Rees",
     5         "title": "Sayings of the Century",
     6         "price": 8.95
     7       },
     8       { "category": "fiction",
     9         "author": "Evelyn Waugh",
    10         "title": "Sword of Honour",
    11         "price": 12.99,
    12         "isbn": "0-553-21311-3"
    13       }
    14     ],
    15     "bicycle": {
    16       "color": "red",
    17       "price": 19.95
    18     }
    19   }
    20 }

    测试代码:

    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); 
    }
    

      

  • 相关阅读:
    Java多线程(二) synchronized 针对对象进行锁定
    微信公众号 openId获取
    Java多线程(一) Thread和 Runnable
    设计模式
    vue城市选择组件
    分享几个简单的技巧让你的 vue.js 代码更优雅
    手把手教你vue配置请求本地json数据
    详解vue全局组件与局部组件使用方法
    细说vue axios登录请求拦截器
    在Vue项目中加载krpano全景图
  • 原文地址:https://www.cnblogs.com/rrl92/p/7879004.html
Copyright © 2020-2023  润新知