在 Jayway JSONPath 中,first() 函数用来获取数组中的第一个元素。
注意:first() 函数并不是标准 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 }, { "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 }
如果执行 $.store.book.first() 表达式将获取第一本书,JSON 如下:
{ "category": "reference", "author": "Nigel Rees", "title": "Sayings of the Century", "price": 8.95 }
Java 示例:
package com.hxstrive.json_path.function; import com.jayway.jsonpath.JsonPath; /** * first() 函数 * @author hxstrive.com */ public class FunctionDemo09 { public static void main(String[] args) { String 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" + " }," + " {" + " \"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" + "}"; Object obj = JsonPath.read(json, "$.store.book.first()"); System.out.println(obj); } }
运行示例,输出如下:
{category=reference, author=Nigel Rees, title=Sayings of the Century, price=8.95}