微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

bash – 在shell中逐列解析Json数据

当我运行命令时,我得到这样的响应
{

    "status": "available","managed": true,"name":vdisk7,"support":{
    "status": "supported"
    },"storage_pool": "pfm9253_pfm9254_new","id": "ff10abad"-2bf-4ef3-9038-9ae7f18ea77c","size":100
},

以及数百种此类列表或词典
我想要一个做这种事情的命令

if name = "something",get the id

任何可以帮助我学习这类命令的链接都将受到高度赞赏

我努力了

awk'{if($2 ==“something”)打印$0;}’

但我认为响应是在Json中,因此colum明智的awk格式化不起作用.

此外,它只是我需要运行的一个命令,所以我不想使用任何外部库.

JSON解析器更适合此任务

awk和sed是解析面向行的文本的实用程序,但不是json.如果你的json格式会改变怎么办? (有些线会在一条线上吗?).

你应该使用任何标准的json解析器.或者使用一些强大的脚本语言,例如PHP,Python,Ruby等.

我可以为您提供有关如何使用python执行此操作的示例.

如果我不能使用强大的脚本语言怎么办?

如果你完全不能使用python,那么有实用程序jq:link

如果你有一些最近的发行版,jq可能已经在存储库中(例如:Ubuntu 13.10在repos中有它).

我可以用python!

我会使用简单的python内联脚本来做到这一点.

例如,我们有一些some_command作为结果返回json.

我们必须得到数据的价值[“名称”].

开始了:

some_command | python -c "import json,sys; print json.load(sys.stdin)['name']"

它会在你的情况下输出vdisk7

为此,你需要确定,json是完全有效的.

如果你有一个json对象列表:

[
  {
    ...
    "name": "vdisk17"
    ...
  },{
    ...
    "name": "vdisk18"
    ...
  },{
    ...
    "name": "vdisk19"
    ...
  },...
]

您可以使用一些列表推导:

some_command | python -c "import json,sys; [sys.stdout.write(x['name'] + '\n') for x in json.load(sys.stdin)]"

它将输出

vdisk17
vdisk18
vdisk19

原文地址:https://www.jb51.cc/bash/386912.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐