当前位置: 首页 > news >正文

乐清做网站培训wordpress托管

乐清做网站培训,wordpress托管,自己做网站 微信,肇庆网站建设解决方案在shell脚本中,当我们需要对JSON数据(例如ceph、kubernetes等一些命令的输出,或是调用API获得的响应)进行处理和提取时,如果使用传统的文本三剑客sed、awk和grep,命令将会非常臃肿不可读。虽然这三个命令在…

在shell脚本中,当我们需要对JSON数据(例如ceph、kubernetes等一些命令的输出,或是调用API获得的响应)进行处理和提取时,如果使用传统的文本三剑客sed、awk和grep,命令将会非常臃肿不可读。虽然这三个命令在处理松散结构的数据时很有用,但当面对JSON这类数据时,却显得不够优雅。

jq就是这样一个命令行工具,专门用于处理JSON数据,特别适用于shell脚本。

jq命令的使用

首先我们需要安装jq命令:yum install jq -y

创建如下的示例文件(一张学生成绩表):

# cat test.json
[{ "name": "zhangsan", "gender": "male", "score": 80 },{ "name": "lisi", "gender": "male", "score": 90 },{ "name": "wangerma", "gender": "female", "score": 100 }
]

jq命令的标准语法为jq [options] <jq filter> [file...],最简单的过滤器为.,它将输入原封不动地转换为输出(会做格式化、高亮),例如:

#  jq '.' test.json 
[{"name": "zhangsan","gender": "male","score": 80},{"name": "lisi","gender": "male","score": 90},{"name": "wangerma","gender": "female","score": 100}
]

这个命令可以用于检测输入是否为合格的json,例如将test.json修改为:

# cat test.json
[{ "name": "zhangsan", "gender": "male", "score": 80 },{ "name": "lisi", "gender": "male", "score": 90 },{ "name": "wangerma", "gender": "female", "score": 100 }

则命令会报错:

#  jq '.' test.json 
parse error: Unfinished JSON term at EOF at line 6, column 0

所以我们可以写如下shell作判断:

#!/bin/bash
if jq '.' test.json >/dev/null 2>&1
thenecho "valid json"
else echo "invalid json"
fi

检索键值

如果我们将需要获取所有学生的姓名列表,如下:

["zhangsan","lisi","wangerma"
]

该怎么做?为此我们需要先使用数组迭代器.[]来获取列表中每一项值:

#  jq '.[]' test.json 
{"name": "zhangsan","gender": "male","score": 80
}
{"name": "lisi","gender": "male","score": 90
}
{"name": "wangerma","gender": "female","score": 100
}

然后获取每一项输出的name键值,这里使用我们熟悉的管道符|

#  jq '.[] | .name' test.json 
"zhangsan"
"lisi"
"wangerma"

如果想要去掉输出中的双引号,可以使用-r参数输出原始字符串:

#  jq -r '.[] | .name' test.json 
zhangsan
lisi
wangerma

接下来我们可以在过滤器的最外层加上[]来讲结果转换为列表:

#  jq '[.[] | .name]' test.json 
["zhangsan","lisi","wangerma"
]

以上过滤器的表达式看起来似乎有些臃肿了,好在jq提供了map函数,因此我们可以将上述表达式替换为:

#  jq 'map(.name)' test.json 
["zhangsan","lisi","wangerma"
]

使用add函数对键值进行求和

仿照上述语法,我们可以可以获得所有学生的成绩列表:

#  jq 'map(.score)' test.json 
[80,90,100
]

同样。使用管道符|add函数,即可轻松获取所有学生的成绩总和:

#  jq 'map(.score) | add' test.json 
270

使用select获取部分键值

如果我们想要对所有男生的成绩进行求和,就需要使用select(condition)函数了,所有conditiontrue的输入会被保留,false则会被丢弃,如我们获取所有性别为男的数据gender == "male"

#  jq 'map(select(.gender == "male"))' test.json 
[{"name": "zhangsan","gender": "male","score": 80},{"name": "lisi","gender": "male","score": 90}
]

进一步获取所有男生的分数:

#  jq 'map(select(.gender == "male").score)' test.json 
[80,90
]

最后求和:

#  jq 'map(select(.gender == "male").score) | add' test.json 
170

将输入转换为新的格式输出

如果我们想将上述步骤中的输出合并为一个新的json数据并输出,则可以使用如下方式进行格式化输出:

#  jq '{ students: map(.name), totalscore: map(.score) | add, totalmalescore: map(select(.gender == "male").score) | add }' test.json 
{"students": ["zhangsan","lisi","wangerma"],"totalscore": 270,"totalmalescore": 170
}

总结

在shell脚本中处理json数据,jq命令是个很好的选择。

本教程将对这个命令的用法只进行了简单入门介绍,如需了解详细语法,可以参看官方文档:https://jqlang.github.io/jq/manual/

http://www.yayakq.cn/news/634890/

相关文章:

  • 网站的引导页怎么做的wordpress没有登陆框
  • 南京高端网站制作公司wordpress集成dplayer
  • 建站公司学习网页音频提取工具
  • 石家庄企业如何建网站广东网站建设智搜宝
  • 陕西省城乡住房建设部网站html设计主题网站代码
  • 网页链接制作生成常州seo关键词排名
  • 自建网站的步骤网站开发学哪种语言
  • 满城建设局网站东莞网站建设排名公司
  • 百合视频做爰视频网站北京app建设
  • 网站内搜索功能怎么做wordpress 边框
  • 网站建设接外包流程图湖南招标网官网
  • 地域购物网站一级消防工程师考试难度有多大
  • 网站开发与网页制作难不难做水果生意去那个网站
  • 网站快速注册做网站好还是做淘宝好
  • 门户网站建设情况自查报告网站建设与代运营介绍
  • 长沙教育建设信息网站科技有限公司英文
  • 网站微信分享链接怎么做的重庆文旅急了
  • 做电子请柬的网站品牌服务推广
  • c 网站开发简单实例教程短网址怎么生成
  • 网站下载不了怎么解决免费追剧的软件
  • 唐山模板网站建设生成器在线制作免费
  • 公司网站制作设计价格衡阳市建设工程质量监督站网站
  • 十大装饰公司泉州百度seo公司
  • 网站建设图片路径错了 怎么改电脑做系统教学网站
  • 电销系统多少钱一套郑州seo联系搜点网络效果好
  • 网站建设wesnowsat北京网站建设公司分形
  • 自己建个购物网站网站建设 手机
  • 深圳网站设计公司龙岗合肥seo搜索优化
  • 网站建设中的板块名称北京住房与城乡建设网站
  • 生鲜网站模板网站建设怎样设置动态背景