<
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。
为什么这么说呢?考虑一种情况,当向集合中插入对象时,如何判别在集合中是否已经存在该对象了?(注意:集合中不允许重复的元