alibaba/fastjson 之 JSONPath

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);


    }


}

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值