jq 工具及其常用用法
在处理 JSON 数据时,我们经常需要在命令行中进行过滤、查询和编辑的操作。jq 是一个强大的命令行 JSON 处理工具,它可以让我们轻松地对 JSON 数据进行各种操作。本文将简要介绍 jq 的基本概念和常用功能,并提供一些实际的例子。
一、jq 简介
jq 是一个轻量级且灵活的命令行 JSON 处理器。它允许你基于键、值和数组索引来提取、过滤和修改 JSON 数据。jq 主要有以下特性:
- 基于流式处理,适用于大型 JSON 数据文件。
- 提供了丰富的操作符和函数,与 Unix 的管道(pipe)和 I/O 重定向兼容。
- 支持条件过滤、字符串操作、数学运算和自定义函数等高级功能。
二、安装 jq
在大多数 Linux 发行版上,可以通过包管理器轻松安装 jq:
- 在基于 Debian 的发行版上:
sudo apt-get install jq - 在基于 RHEL 的发行版上:
sudo yum install jq - 在 Arch Linux 上:
sudo pacman -S jq - 在 macOS 上,可以使用 Homebrew 安装:
brew install jq
三、常用 jq 用法
以下是 jq 的一些常见用法。
1. 读取属性值
要从输入的 JSON 对象中提取属性值,可以使用.
操作符。
举例:有一个名为 sample.json
的文件,内容如下:
{
"name": "Alice",
"age": 30,
"city": "New York"
}
提取名字:
cat sample.json | jq '.name'
输出结果:
"Alice"
2. 过滤数组元素(列表中嵌套字典)
要对数组元素进行过滤,可以使用 []
操作符。
举例:有一个名为 students.json
的文件,内容如下:
[
{
"name": "Alice",
"age": 30,
"city": "New York"
},
{
"name": "Bob",
"age": 25,
"city": "San Francisco"
},
{
"name": "Charlie",
"age": 23,
"city": "Los Angeles"
}
]
提取所有名字:
cat students.json | jq '.[].name'
输出结果:
"Alice"
"Bob"
"Charlie"
3. 选择特定数组元素
如果要返回具有某些属性的特定元素,则可以使用选择器。例如,要选择年龄超过 25 岁的学生:
cat students.json | jq '.[] | select(.age > 25)'
输出结果:
{
"name": "Alice",
"age": 30,
"city": "New York"
}
[root@mcw02 machangwei]# cat mcwstudents.json | jq '.[]'
{
"name": "Alice",
"age": 30,
"city": "New York"
}
{
"name": "Bob",
"age": 25,
"city": "San Francisco"
}
{
"name": "Charlie",
"age": 23,
"city": "Los Angeles"
}
[root@mcw02 machangwei]# cat mcwstudents.json | jq '.[0]'
{
"name": "Alice",
"age": 30,
"city": "New York"
}
[root@mcw02 machangwei]# cat mcwstudents.json | jq '.[] | select(.age > 25) '
{
"name": "Alice",
"age": 30,
"city": "New York"
}
[root@mcw02 machangwei]#
4. 排序和唯一化数组
可以使用 sort
,sort_by()
和 unique
函数对数组进行操作。
例如,对来自 sample-array.json
文件的年龄进行排序和去重:
[30, 20, 25, 30, 25, 20]
排序且去重:
cat sample-array.json | jq 'unique | sort'
输出结果:
[
20,
25,
30
]
[root@mcw02 machangwei]# vim sample-array.json
[root@mcw02 machangwei]# cat sample-array.json
[30, 20, 25, 30, 25, 20]
[root@mcw02 machangwei]# cat sample-array.json| jq 'unique'
[
20,
25,
30
]
[root@mcw02 machangwei]# cat sample-array.json| jq 'unique|sort'
[
20,
25,
30
]
[root@mcw02 machangwei]#
5. 修改数据
除了筛选和查询,jq 还支持创建和修改数据。例如,为 students.json
中的每个学生添加 “isActive” 属性:
cat students.json | jq '.[] | {name, age, city, isActive: true}'
输出结果:
{
"name": "Alice",
"age": 30,
"city": "New York",
"isActive": true
}
{
"name": "Bob",
"age": 25,
"city": "San Francisco",
"isActive": true
}
{
"name": "Charlie",
"age": 23,
"city": "Los Angeles",
"isActive": true
}
可以添加键值对,但只是显示发生改变,并没有修改掉文件内容
[root@mcw02 machangwei]# cat mcwstudents.json
[
{
"name": "Alice",
"age": 30,
"city": "New York"
},
{
"name": "Bob",
"age": 25,
"city": "San Francisco"
},
{
"name": "Charlie",
"age": 23,
"city": "Los Angeles"
}
]
[root@mcw02 machangwei]# cat mcwstudents.json |jq '.[]'
{
"name": "Alice",
"age": 30,
"city": "New York"
}
{
"name": "Bob",
"age": 25,
"city": "San Francisco"
}
{
"name": "Charlie",
"age": 23,
"city": "Los Angeles"
}
[root@mcw02 machangwei]#
[root@mcw02 machangwei]# cat mcwstudents.json |jq '.[]|{name,age,city,isActive:true,shengao:164cm}'
jq: error: syntax error, unexpected IDENT, expecting '}' (Unix shell quoting issues?) at <top-level>, line 1:
.[]|{name,age,city,isActive:true,shengao:164cm}
jq: 1 compile error
[root@mcw02 machangwei]# cat mcwstudents.json |jq '.[]|{name,age,city,isActive:true,shengao:"164cm"}'
{
"name": "Alice",
"age": 30,
"city": "New York",
"isActive": true,
"shengao": "164cm"
}
{
"name": "Bob",
"age": 25,
"city": "San Francisco",
"isActive": true,
"shengao": "164cm"
}
{
"name": "Charlie",
"age": 23,
"city": "Los Angeles",
"isActive": true,
"shengao": "164cm"
}
[root@mcw02 machangwei]# cata mcwstudents.json
-bash: cata: command not found
[root@mcw02 machangwei]# cat mcwstudents.json
[
{
"name": "Alice",
"age": 30,
"city": "New York"
},
{
"name": "Bob",
"age": 25,
"city": "San Francisco"
},
{
"name": "Charlie",
"age": 23,
"city": "Los Angeles"
}
]
[root@mcw02 machangwei]#
如下,写上哪个键,就会显示哪个键的。如果不存在的键,需要写上值;如果已经存在的键,不需要写值,默认是文件里的值;如果已经存在的键,又写上值,那么就会替换为修改的值。上面操作不会改变原文件。不过想要这个结果,可以追加到新的文件中。
[root@mcw02 machangwei]# cat mcwstudents.json
[
{
"name": "Alice",
"age": 30,
"city": "New York"
},
{
"name": "Bob",
"age": 25,
"city": "San Francisco"
},
{
"name": "Charlie",
"age": 23,
"city": "Los Angeles"
}
]
[root@mcw02 machangwei]#
[root@mcw02 machangwei]# cat mcwstudents.json |jq '.[]|{name,age:18,shengao:"164cm"}'
{
"name": "Alice",
"age": 18,
"shengao": "164cm"
}
{
"name": "Bob",
"age": 18,
"shengao": "164cm"
}
{
"name": "Charlie",
"age": 18,
"shengao": "164cm"
}
[root@mcw02 machangwei]# cat mcwstudents.json
[
{
"name": "Alice",
"age": 30,
"city": "New York"
},
{
"name": "Bob",
"age": 25,
"city": "San Francisco"
},
{
"name": "Charlie",
"age": 23,
"city": "Los Angeles"
}
]
[root@mcw02 machangwei]#
6、字典嵌套列表嵌套字典
[root@mcw02 machangwei]# vim xiaoma.json
[root@mcw02 machangwei]# cat xiaoma.json
{
"data": [
{
"appid": "222",
"companyId": 1,
"projectId": 93,
"projectName": "Cloak Private Browser(H5)",
"projectType": 0,
"remark": "",
"roleName": "root"
},
{
"appid": "111",
"companyId": 1,
"projectId": 95,
"projectName": "tyj_test",
"projectType": 0,
"remark": "",
"roleName": "root"
}
],
"return_code": 0,
"return_message": "success",
"showStackMessage": false
} [root@mcw02 machangwei]# cat xiaoma.json |jq '.data[0]'
{
"appid": "222",
"companyId": 1,
"projectId": 93,
"projectName": "Cloak Private Browser(H5)",
"projectType": 0,
"remark": "",
"roleName": "root"
}
[root@mcw02 machangwei]# cat xiaoma.json |jq '.data[0].appid'
"222"
[root@mcw02 machangwei]#
四、总结
jq 是个非常强大的命令行 JSON 处理工具,支持各种数据操作功能,能够帮助你在处理 JSON 数据时更加便捷和高效。本文列举了一些常用的 jq 使用案例,但 jq 的功能远不止于此。更多丰富的功能可以在官方文档(点击查看)中找到。 熟练掌握 jq 有助于提高命令行处理 JSON 数据的能力,为其它处理和分析工具提供更方便的数据源。
来源:https://zhuanlan.zhihu.com/p/661537804
jq 工具及其常用用法的更多相关文章
- web报表工具FineReport常用函数的用法总结(日期和时间函数)
web报表工具FineReport常用函数的用法总结(日期和时间函数) 说明:凡函数中以日期作为参数因子的,其中日期的形式都必须是yy/mm/dd.而且必须用英文环境下双引号(" " ...
- MySQL的mysqldump工具的基本用法
导出要用到MySQL的mysqldump工具,基本用法是: shell> mysqldump [OPTIONS] database [tables] 如果你不给定任何表,整个数据库将 ...
- linux 系统监控、诊断工具之 lsof 用法简介
1.lsof 简介 lsof 是 Linux 下的一个非常实用的系统级的监控.诊断工具. 它的意思是 List Open Files,很容易你就记住了它是 "ls + of"的组合 ...
- grep知识及常用用法梳理
1. grep语法及其参数说明 grep是文本搜索工具,能根据用户指定的'PATTERN模式'目标文本进行逐行匹配检查,注意grep默认会以 行 为单位打印匹配到的行. 以下是grep命令的语法及常用 ...
- centos的vi常用用法
centos的vi常用用法 vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任何最新的文本编辑器,这里只是简单地介绍一下它的用法和一小部分指令.由于对Unix及Linux系统的 ...
- MySql与SqlServer的一些常用用法的差别
MySql与SqlServer的一些常用用法的差别 本文为转载 本文将主要列出MySql与SqlServer不同的地方,且以常用的存储过程的相关内容为主. 1. 标识符限定符 SqlServer [] ...
- [转]ssh常用用法小结
ssh常用用法小结 1.连接到远程主机: 命令格式 : ssh name@remoteserver 或者 ssh remoteserver -l name 说明:以上两种方式都可以远程登录到远程主机, ...
- 【三支火把】---一份程序看懂C程序printf()的几种常用用法
闲来继续巩固我的学习之路,今天略微整理了一下,C程序中Printf()的一些常用用法,虽然自己以前好像会,但是不够系统,今天大致整理了一些,先贴上来看看,以后在看到其他,继续补充,希望能帮到一些像我一 ...
- grep参数说明及常用用法
grep参数说明及常用用法 趁着午休的时间把自己经常使用的一些grep命令整理一下. 方便以后查看. 后续会逐步把awk/sed/find等常用的命令理一理. 增强下记忆. 也算是对得起自己了. ^^ ...
- ssh常用用法小结
ssh常用用法小结 1.连接到远程主机: 命令格式 : ssh name@remoteserver 或者 ssh remoteserver -l name 说明:以上两种方式都可以远程登录到远程主机, ...
随机推荐
- npm 直接安装 GitHub/GitLab 仓库代码及 npm link 本地调试
一.npm 直接安装 GitHub/GitLab 仓库代码 语法 npm install <git remote url> 示例 命令: npm i git@github.com:maze ...
- C++ 中的可移植性和跨平台开发
在当今软件开发行业中,跨平台开发已经成为了一种非常流行的方式.C++作为一门强大的编程语言,也被广泛应用于跨平台开发中.然而,由于不同操作系统的差异和限制,C++在不同的平台上的表现可能会有所不同.为 ...
- MyBatis-Plus 代码生成(旧)
MyBatis-Plus官网的代码生成器配置不是特别全,在此整理了较为完整的配置,供自己和大家查阅学习. // 代码生成器 AutoGenerator mpg = new AutoGenerator( ...
- 动态库 DLL 封装三:对dll二次封装,并将回调函数放出去,供别人调用
背景: 我需要对一个dll进行二次封装,其中有一个接口,里面的参数需要传回调函数. 需求: 这个回调函数,我需要开放出去,让别人调用我的dll时,自己写这个回调函数 示例: // 回调原型 VOID ...
- 【Windbg Preview】Failed to load data access DLL, 0x80004005
最近使用Windbg的时候一直在用Preview版本,感觉解析一下就能直接加载起环境来太爽了.不过最近遇到一个dump加载不起来了. 但是最近一次加载却失败了,尝试了很久也不行 Failed to l ...
- 10个常用的JS工具库,80%的项目都在用
高手区别于普通人的重要一点是,他们善于利用工具,把更多的时间留给了规划和思考.写代码也是同样的道理,工具用好了,你就有更多的时间来规划架构和攻克难点.今天就给大家分享一下当前最流行的 js 工具库,如 ...
- MySQL 分析查询与来源机器
当前分析针对版本:MariaDB 10.5 线上出现报错:can't create more than max_prepared_stmt_count statements.造成这个错误的直接原因就是 ...
- 【NOIP2013模拟联考8】匹配(match) 题解
B 组都说看不懂--我也解释不清啊--只能写这么详细了 其实就是道板题 省流:f[i][s][j]表示字符串长度i,匹配情况s,ac自动机节点j Problem Description 给定k个字符串 ...
- winform之在主窗体中不显示子窗体的菜单栏
在MDi窗体嵌入子窗体后不显示菜单栏 背景: 由于之前做的一个程序的功能全部都是放在一个界面上的,有一个功能能够在数据库查询数据,并返回到界面上,数据量比较小的时候还好,但是数据量多了,导致它阻塞的其 ...
- 轻松复现一张AI图片
轻松复现一张AI图片 现在有一个非常漂亮的AI图片,你是不是想知道他是怎么生成的? 今天我会交给大家三种方法,学会了,什么图都可以手到擒来了. 需要的软件 在本教程中,我们将使用AUTOMATIC11 ...