JSON解析器jq小解

来源:互联网 发布:现在有什么网络歌曲 编辑:程序博客网 时间:2024/05/29 14:49

在使用mesos HTTP API时需要获取其master stats,用到了jq,这里做个记录吧

JSON是前端编程经常用到的格式,对于PHP或者Python,解析JSON都不是什么大事,尤其是PHP的json_encode和json_decode,干的相当的漂亮。Linux下也有处理处理JSON的神器:jq。

对于JSON格式而言,jq就像sed/awk/grep这些神器一样的方便,而也,jq没有乱七八糟的依赖,只需要一个binary文件jq,就足矣。下面我们看下jq的使用。

1 格式化JSON

root@$:~/code/php/json$ cat json_raw.txt {"name":"Google","location":{"street":"1600 Amphitheatre Parkway","city":"Mountain View","state":"California","country":"US"},"employees":[{"name":"Michael","division":"Engineering"},{"name":"Laura","division":"HR"},{"name":"Elise","division":"Marketing"}]}

上面的JSON是PHP json_encode之后,echo出来的字符串,很明显,可读性太差。前一阵子写文档,需要将前后段JSON写入文档,我当时是用是网上的JSON格 式化工具做的。事实上,jq就可以检查JSON的合法性,并把JSON格式化成更友好更可读的格式:

    cat json_raw.txt | jq .

看到上图,将一团乱麻的JSON格式化成个更可读的形式。其实背后另外检查了JSON的合法性。如果JSON不合法,jq .会报错。我故意写个错误的JSON:

root@$:~/code/php/json$ cat json_err.txt {"name":"Google","location":{"street":"1600 Amphitheatre Parkway","city":"Mountain View","state":"California","country":"US"},"employees":[{"name":"Michael","division":"Engineering"}{"name":"Laura","division":"HR"},{"name":"Elise","division":"Marketing"}]}

上面JSON中加粗和斜体部分,遗漏了一个逗号,所以这个JSON是错误的,jq轻松的可以轻松的检查出来:

    manu@manu:~/code/php/json$ cat json_err.txt |jq .    parse error: Expected separator between values at line 1, column 183 2 JSON parse

jq如何解析JSON,根据key获取value?

    {        “key_1”:"value_1",        “key_2”:"value_2",    }如何根据key获取value?     jq '.key'

解析不存在的元素,会返回null

    echo '{"foo": 42, "bar": "less interesting data"}' | jq .nofoo    null

3 JSON nested parse(嵌套解析)

    cat json_raw.txt | jq '.location.state'    "California"

4 JSON parse array

    cat json_raw.txt | jq '.employees[1].name'    "Laura"

5 内建函数
jq还有一些内建函数如 key,has
key是用来获取JSON中的key元素的:

cat json_raw.txt | jq 'keys'[  "employees",  "location",  "name"]

has是用来是判断是否存在某个key:

cat json_raw.txt | jq 'has("name")'truecat json_raw.txt | jq 'has("noexisted")'false参考:https://stedolan.github.io/jq/tutorial/转载的

查看原文:http://www.zoues.com/index.php/2016/01/20/jsonjq/

0 0
原创粉丝点击