网站首页 > 技术文章 正文
0x00 jq介绍
jq是一个轻量级的灵活的处理json对象的命令。支持linux、windows。
0x01 二进制安装
wget -O jq https://github.com/stedolan/jq/releases/download/jq-1.5/jq-linux64
chmod +x ./jq
cp jq /usr/bin
0x02 使用yum安装
yum -y install epel-release
yum -y install jq
0x03 使用
1、格式化输出
curl http://ip.taobao.com/service/getIpInfo.php?ip=8.8.8.8 2>> /dev/null | jq
{
"code": 0,
"data": {
"ip": "8.8.8.8",
"country": "美国",
"area": "",
"region": "XX",
"city": "XX",
"county": "XX",
"isp": "Level3",
"country_id": "US",
"area_id": "",
"region_id": "xx",
"city_id": "xx",
"county_id": "xx",
"isp_id": "200053"
}
}
2、获取指定字段的数据
curl http://ip.taobao.com/service/getIpInfo.php?ip=8.8.8.8 2>> /dev/null | jq -r '.code,.data.ip,.data.country'
0
8.8.8.8
美国
3、提取指定的字段保存成csv文件
curl http://ip.taobao.com/service/getIpInfo.php?ip=8.8.8.8 2>> /dev/null | jq -r '[(.code|tostring),.data.ip,.data.country]|join(",")'
0,8.8.8.8,美国
注释:
.code|tostring:取code字段的值并转化为string类型
[]:数组
join(","):数组中的元素通过","连接。
4、csv转换成json字符串
cat /tmp/1.csv
0,8.8.8.8,美国
0,8.8.8.7,美国
0,8.8.2.7,美国
0,81.8.2.7,土耳其
jq -R 'split(",")|{"code":.[0],"ip":.[1],"country":.[2]}' /tmp/1.csv
{
"code": "0",
"ip": "8.8.8.8",
"country": "美国"
}
{
"code": "0",
"ip": "8.8.8.7",
"country": "美国"
}
{
"code": "0",
"ip": "8.8.2.7",
"country": "美国"
}
{
"code": "0",
"ip": "81.8.2.7",
"country": "土耳其"
}
5、 -c/--compact-output:jq 默认是pretty-prints JSON 输出,加上这个参数,一行一个json对象。
jq -R -c 'split(",")|{"code":.[0],"ip":.[1],"country":.[2]}' /tmp/1.csv
{"code":"0","ip":"8.8.8.8","country":"美国"}
{"code":"0","ip":"8.8.8.7","country":"美国"}
{"code":"0","ip":"8.8.2.7","country":"美国"}
{"code":"0","ip":"81.8.2.7","country":"土耳其"}
6、复杂json查询
complexJson='{"uid":"777","nameInfo":[{"firstName":"Jim","lastName":"Green"},{"firstName":"Lei","lastName":"Li"}]}'
echo ${complexJson} |jq
{
"uid": "777",
"nameInfo": [
{
"firstName": "Jim",
"lastName": "Green"
},
{
"firstName": "Lei",
"lastName": "Li"
}
]
}
echo ${complexJson} |jq -r '.nameInfo[].lastName'
结果:
Green
Li
注释:
.nameInfo[].lastName是获取.nameInfo[] json array中每个json object的lastName字段。
猜你喜欢
- 2024-10-19 Node-RED系列(六):Node-RED解析节点的使用
- 2024-10-19 越南指数行情数据API接口(越南指数股票最新行情)
- 2024-10-19 Pinot 架构分析(pod架构)
- 2024-10-19 大模型开发者实战揭秘:SFT指令微调数据构建的全方位指南
- 2024-10-19 27K star!这款开源可视利器帮你一眼看穿JSON
- 2024-10-19 MongoDB常用特性一览(mongodb4.2新特性)
- 2024-10-19 轻量级的原生JavaScript的Excel插件——JExcel
- 2024-10-19 5万字长文!搞定Spark方方面面(五)
- 2024-10-19 越南指数清单列表数据API接口(越南指数清单列表数据api接口在哪)
- 2024-10-19 【Python基础】当JSON遇上Python,表格化真的那么难吗?
- 最近发表
- 标签列表
-
- cmd/c (64)
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- sqlset (64)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)