加入收藏 | 设为首页 | 会员中心 | 我要投稿 东莞站长网 (https://www.0769zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 服务器 > 搭建环境 > Windows > 正文

如何用Linux命令行工具解析和格式化输出JSON

发布时间:2019-08-08 19:15:41 所属栏目:Windows 来源:Ostechnix
导读:副标题#e# JSON 是一种轻量级且与语言无关的数据存储格式,易于与大多数编程语言集成,也易于人类理解 当然,如果格式正确的话。JSON 这个词代表 Java Script Object Notation,虽然它以 JavaScript 开头,而且主要用于在服务器和浏览器之间交换数据,但现

来自维基百科的 JSON 数据示例:

  1. {
  2. "firstName": "John",
  3. "lastName": "Smith",
  4. "age": 25,
  5. "address": {
  6. "streetAddress": "21 2nd Street",
  7. "city": "New York",
  8. "state": "NY",
  9. "postalCode": "10021"
  10. },
  11. "phoneNumber": [
  12. {
  13. "type": "home",
  14. "number": "212 555-1234"
  15. },
  16. {
  17. "type": "fax",
  18. "number": "646 555-4567"
  19. }
  20. ],
  21. "gender": {
  22. "type": "male"
  23. }
  24. }

我将在本教程中将此 JSON 数据用作示例,将其保存为 sample.json

假设我想从 sample.json 文件中过滤出地址。所以命令应该是这样的:

  1. $ jq .address sample.json

示例输出:

  1. {
  2. "streetAddress": "21 2nd Street",
  3. "city": "New York",
  4. "state": "NY",
  5. "postalCode": "10021"
  6. }

再次,我想要邮政编码,然后我要添加另一个对象标识符-索引,即另一个过滤器。

  1. $ cat sample.json | jq .address.postalCode

另请注意,过滤器区分大小写,并且你必须使用完全相同的字符串来获取有意义的输出,否则就是 null。

从 JSON 数组中解析元素

JSON 数组的元素包含在方括号内,这无疑是非常通用的。

要解析数组中的元素,你必须使用 [] 标识符以及其他对象标识符索引。

在此示例 JSON 数据中,电话号码存储在数组中,要从此数组中获取所有内容,你只需使用括号,像这个示例:

  1. $ jq .phoneNumber[] sample.json

假设你只想要数组的第一个元素,然后使用从 0 开始的数组对象编号,对于第一个项目,使用 [0],对于下一个项目,它应该每步增加 1。

  1. $ jq .phoneNumber[0] sample.json

脚本编程示例

假设我只想要家庭电话,而不是整个 JSON 数组数据。这就是用 jq 命令脚本编写的方便之处。

  1. $ cat sample.json | jq -r '.phoneNumber[] | select(.type == "home") | .number'

首先,我将一个过滤器的结果传递给另一个,然后使用 select 属性选择特定类型的数据,再次将结果传递给另一个过滤器。

解释每种类型的 jq 过滤器和脚本编程超出了本教程的范围和目的。强烈建议你阅读 jq 手册,以便更好地理解下面的内容。

资源:

  • https://stedolan.github.io/jq/manual/
  • http://www.compciv.org/recipes/cli/jq-for-parsing-json/
  • https://lzone.de/cheat-sheet/jq

【编辑推荐】

  1. 如何查找Linux上的硬件规格?
  2. Window下不用安装虚拟机,也可以玩转Linux,玩转最新Redis
  3. Linux是如何创建进程的?为什么说Linux与其他操作系统不同?
  4. 5个免费的Linux分区管理器
  5. Linux和Windows两种风格的操作系统,创建线程的方式有何不同?
【责任编辑:庞桂玉 TEL:(010)68476606】
点赞 0

(编辑:东莞站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!