< groupId > com.jayway.jsonpath </ groupId > < artifactId > json-path </ artifactId > < version > RELEASE </ version > </ dependency > 操作符/函数/运算法 查询根元素。这将启动所有路径表达式。 当前节点由过滤谓词处理。 通配符,必要时可用任何地方的名称或数字。 深层扫描。 必要时在任何地方可以使用名称。 .<name> 点,表示子节点 ['<name>' (, '<name>')] 括号表示子项 [<number> (, <number>)] 数组索引或索引 [start:end] 数组切片操作 [?(<expression>)] 过滤表达式。 表达式必须求值为一个布尔值。

函数可以在路径的尾部调用,函数的输出是路径表达式的输出,该函数的输出是由函数本身所决定的。

min() 提供数字数组的最小值 Double max() 提供数字数组的最大值 Double avg() 提供数字数组的平均值 Double stddev() 提供数字数组的标准偏差值 Double length() 提供数组的长度 Integer
过滤器运算符

过滤器是用于筛选数组的逻辑表达式。一个典型的过滤器将是[?(@.age > 18)],其中@表示正在处理的当前项目。 可以使用逻辑运算符&&和||创建更复杂的过滤器。 字符串文字必须用单引号或双引号括起来([?(@.color == ‘blue’)] 或者 [?(@.color == “blue”)]).

left等于right(注意1不等于’1’) 匹配正则表达式[?(@.name =~ /foo.*?/i)] 左边存在于右边 [?(@.size in [‘S’, ‘M’])] 左边不存在于右边 (数组或字符串)长度 empty (数组或字符串)为空 "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 获取json中store下book下的所有author值
$..author 获取所有json中所有author的值
$.store.* 所有的东西,书籍和自行车
$.store..price 获取json中store下所有price的值
$..book[2\] 获取json中book数组的第3个值
$..book[-2\] 倒数的第二本书
$..book[0,1\]
$..book[:2\] 从索引0(包括)到索引2(排除)的所有图书
$..book[1:2\] 从索引1(包括)到索引2(排除)的所有图书
$..book[-2:\] 获取json中book数组的最后两个值
$..book[2:\] 获取json中book数组的第3个到最后一个的区间值
$..book[?(@.isbn)\] 获取json中book数组中包含isbn的所有值
[ $.store.book[?(@.price < 10)\] ](http://jsonpath.herokuapp.com/?path=$.store.book[?(@.price < 10)]) 获取json中book数组中price<10的所有值
[ $..book[?(@.price <= $['expensive'\])] ](http://jsonpath.herokuapp.com/?path=$…book[?(@.price <= $[‘expensive’])]) 获取json中book数组中price<=expensive的所有值
[ $..book[?(@.author =~ /.*REES/i)\] ](http://jsonpath.herokuapp.com/?path=$…book[?(@.author =~ /.*REES/i)]) 获取json中book数组中的作者以REES结尾的所有值(REES不区分大小写) 逐层列出json中的所有值,层级由外到内
$..book.length() 获取json中book数组的长度
String json = "{...}";
String str = JsonPath.read(document, "$.store.book[0].author");
                            
java中为什么重写clone java 为什么要重写hashcode方法
对于包含容器类型的程序设计语言来说,基本上都会涉及到hashCode。在Java中也一样,hashCode方法的主要作用是为了配合基于散列的集合一起正常运行,这样的散列集合包括HashSet、HashMap以及HashTable。   为什么这么说呢?考虑一种情况,当向集合中插入对象时,如何判别在集合中是否已经存在该对象了?(注意:集合中不允许重复的元