JSON Path 语法介绍和使用场景

简介: JSON Path 语法介绍和使用场景

一、什么是JSON Path

JSONPath 之于 JSON,就如 XPath 之于 XML。JSONPath 可以方便对 JSON 数据结构进行内容提取。

下面是一个JSON Path语法的举例:

$.store.book[0].title

二、语法介绍

JsonPath 说明
$ 文档根元素
@ 当前元素
.[] 匹配下级元素
N/A 匹配上级元素,JsonPath不支持此操作符
.. 递归匹配所有子元素
* 通配符,匹配下级元素
N/A 匹配属性,JsonPath不支持此操作符
[] 下标运算符,根据索引获取元素,XPath索引从1开始,JsonPath索引从0开始
[,] 连接操作符,将多个结果拼接成数组返回,可以使用索引或别名
[start:end:step] 数据切片操作,XPath不支持
?() 过滤表达式
() 脚本表达式,使用底层脚本引擎,XPath不支持
N/A 分组,JsonPath不支持

这是一个非常经典的案例,你几乎可以在任何介绍JSON Path的地方看到它,但是很实用。

{ "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
    }
  }
}

配合示例,对应上面表格的语法,下面的举例更好理解。

JsonPath Result
$.store.book[*].author 所有book的author节点
$..author 所有author节点
$.store.* store下的所有节点,book数组和bicycle节点
$.store..price store下的所有price节点
$..book[2] 匹配第3个book节点
$..book[(@.length-1)],或 $..book[-1:] 匹配倒数第1个book节点
$..book[0,1],或 $..book[:2] 匹配前两个book节点
$..book[?(@.isbn)] 过滤含isbn字段的节点
$..book[?(@.price<10)] 过滤price<10的节点
$..* 递归匹配所有子节点

这个地址可以在线运行 http://jsonpath.com/

三、哪里可以用的到呢?

光有语法可操作意义不大,那么哪里可以用到JSON Path呢?

1. Java

Jayway JsonPath ,用于读取 JSON 文档的 Java DSL。

项目地址: https://github.com/json-path/JsonPath

2. PHP

JsonPath,JsonPath的PHP实现。

项目地址: https://github.com/Galbar/JsonPath-PHP

3. JavaScript

jsonpath, 使用 JSONPath 表达式查询 JavaScript 对象。 用于 Node.js 的强大/安全的 JSONPath 引擎。

项目地址: https://github.com/dchester/jsonpath

4. Python

jsonpath-ng,旨在符合标准的 Python JSONPath 的最终实现,包括算术和二进制比较运算符,并为元编程提供清晰的 AST。

项目地址:https://pypi.org/project/jsonpath-ng/

5. Go

Jsonpath,JsonPath的PHP实现。

项目地址:https://github.com/yalp/jsonpath

四、总结

JSON Path 作为一个语法标准,实现了对JSON的便捷读取。另外,各种语言的JSON Path实现的项目名称都差不多。

相关文章
|
3月前
|
存储 JSON 前端开发
JSON数组的概念、语法和用法
JSON数组的概念、语法和用法
511 3
|
2月前
|
JSON 关系型数据库 MySQL
实时计算 Flink版产品使用问题之在使用CDAS语法同步MySQL数据到Hologres时,如果开启了字段类型宽容模式,MySQL中的JSON类型会被转换为什么
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
1月前
|
JSON Java 数据格式
前后端数据交换,JSON基础语法和JSON数据和Java对象转换,最快的对象转换,JSON{““}字符串如何写User{id=1,username=‘zhangsan‘,password=‘123‘}
前后端数据交换,JSON基础语法和JSON数据和Java对象转换,最快的对象转换,JSON{““}字符串如何写User{id=1,username=‘zhangsan‘,password=‘123‘}
|
3月前
|
JSON 数据格式 索引
python之JMESPath:JSON 查询语法库示例详解
python之JMESPath:JSON 查询语法库示例详解
38 0
|
3月前
|
JSON JavaScript 前端开发
JSON.stringify() 的 5 种使用场景
JSON.stringify() 的 5 种使用场景
33 0
|
3月前
|
存储 JSON 安全
JSON 语法详解:轻松掌握数据结构(下)
JSON 语法详解:轻松掌握数据结构(下)
JSON 语法详解:轻松掌握数据结构(下)
|
3月前
|
存储 JSON 前端开发
JSON 语法详解:轻松掌握数据结构(上)
JSON 语法详解:轻松掌握数据结构(上)
JSON 语法详解:轻松掌握数据结构(上)
|
3月前
|
JSON JavaScript 前端开发
JSON 语法是怎么样的呢?
JSON 语法是怎么样的呢?
50 2
|
3月前
|
存储 JSON JavaScript
JSON.stringfy 的使用场景介绍
JSON.stringfy 的使用场景介绍
|
3月前
|
JSON JavaScript 前端开发
JSON概念、基础语法及数据和对象转换
JSON概念、基础语法及数据和对象转换
49 0