JOSNPath 是一个非常强大的工具,对于处理 json 对象非常方便。
官方地址:https://github.com/alibaba/fastjson/wiki/JSONPath
本案例采用 fastjson-1.2.58.jar
下载地址:https://search.maven.org/remote_content?g=com.alibaba&a=fastjson&v=LATEST
案例:有这么一个 json 数据
{
"地球": {
"其他国": "其他国",
"中国": {
"a省": {
"b市": {
"c区:cc": {
"d镇": {
"#f村": {
"小张": "28",
"小王": "26"
}
}
}
}
},
"b省": {}
}
}
}
现在要获取 #f村 下的数据,就可以用:
JSONObject jsonObj = (JSONObject)JSONPath.read(json, "地球.中国.a省.b市.c区\\:cc.d镇.\\#f村");
第一个参数: String 类型, 就是把上面的 json 装换成 String.
第二个参数: 匹配路径 ,也就是你要获取的内容路径。
注意: 如果 对象名遇到 : # 等特殊符号
要用 \\ 进行转义,不然会报错。
返回:
{"小张":"28","小王":"26"}
完整代码:
首先,本地建立一个文件,内容就是 上面的 json ,编码格式为 utf-8
import java.io.File;
import java.io.IOException;
import org.apache.commons.io.FileUtils;
import com.alibaba.fastjson.JSONObject;
import com.alibaba.fastjson.JSONPath;
public class TestFastJson {
public static void main(String[] args) throws IOException {
//本地json文件
File file = new File("H:\\json.txt");
String json = FileUtils.readFileToString(file, "utf-8");
JSONObject jsonObj = (JSONObject) JSONPath.read(json, "地球.中国.a省.b市.c区\\:cc.d镇.\\#f村");
System.out.println(jsonObj);
}
}
其他用法可以参考:https://blog.csdn.net/itguangit/article/details/78764212
这里贴 一些常用的方法:
/**
* 使用JSONPrase 解析JSON字符串或者Object对象
* <p>
* read(String json, String path)//直接使用json字符串匹配
* <p>
* eval(Object rootObject, String path) //直接使用 对象匹配
* <p>
* <p>
* {"store":{"bicycle":{"color":"red","price":19.95},"book":[{"author":"Nigel Rees","price":8.95,"category":"reference","title":"Sayings of the Century"},{"author":"Evelyn Waugh","price":12.99,"isbn":"0-553-21311-3","category":"fiction","title":"Sword of Honour"}]}}
*/
@Test
public void test5() {
String jsonStr = "{\n" +
" \"store\": {\n" +
" \"bicycle\": {\n" +
" \"color\": \"red\",\n" +
" \"price\": 19.95\n" +
" },\n" +
" \"book\": [\n" +
" {\n" +
" \"author\": \"刘慈欣\",\n" +
" \"price\": 8.95,\n" +
" \"category\": \"科幻\",\n" +
" \"title\": \"三体\"\n" +
" },\n" +
" {\n" +
" \"author\": \"itguang\",\n" +
" \"price\": 12.99,\n" +
" \"category\": \"编程语言\",\n" +
" \"title\": \"go语言实战\"\n" +
" }\n" +
" ]\n" +
" }\n" +
"}";
JSONObject jsonObject = JSON.parseObject(jsonStr);
log.info(jsonObject.toString());
//得到所有的书
List<Book> books = (List<Book>) JSONPath.eval(jsonObject, "$.store.book");
log.info("books={}", books);
//得到所有的书名
List<String> titles = (List<String>) JSONPath.eval(jsonObject, "$.store.book.title");
log.info("titles={}", titles);
//第一本书title
String title = (String) JSONPath.read(jsonStr, "$.store.book[0].title");
log.info("title={}", title);
//price大于10元的book
List<Book> list = (List<Book>) JSONPath.read(jsonStr, "$.store.book[price > 10]");
log.info("price大于10元的book={}",list);
//price大于10元的title
List<String> list2 =(List<String>) JSONPath.read(jsonStr, "$.store.book[price > 10].title");
log.info("price大于10元的title={}",list2);
//category(类别)为科幻的book
List<Book> list3 = (List<Book>) JSONPath.read(jsonStr,"$.store.book[category = '科幻']");
log.info("category(类别)为科幻的book={}",list3);
//bicycle的所有属性值
Collection<String> values = (Collection<String>) JSONPath.eval(jsonObject, "$.store.bicycle.*");
log.info("bicycle的所有属性值={}",values);
//bicycle的color和price属性值
List<String> read =(List<String>) JSONPath.read(jsonStr, "$.store.bicycle['color','price']");
log.info("bicycle的color和price属性值={}",read);
}
}