在 Jayway JSONPath 中,avg() 函数用来计算数组的平均值,但是在标准的 JSONPath 规范并没有定义 avg() 函数来计算数组的平均值。
假设我们有以下 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 }
如果我们要计算所有书籍的平均价格,此时,可以使用 avg() 函数,表达式为 $..book[*].price.avg(),其中,$..book[*].price 将获取出所有书籍的价格,avg() 函数将计算价格的平均值。
Java 示例:
package com.hxstrive.json_path.function; import com.jayway.jsonpath.JsonPath; /** * avg() 函数 * @author hxstrive.com */ public class FunctionDemo03 { 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, "$..book[*].price"); System.out.println(obj); obj = JsonPath.read(json, "$..book[*].price.avg()"); System.out.println(obj); } }
运行示例,输出如下:
[8.95,12.99,8.99,22.99] 13.48