首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用jq创建JSON

用jq创建JSON
EN

Stack Overflow用户
提问于 2022-01-21 16:36:15
回答 1查看 1.2K关注 0票数 1

我正在尝试从命令"lsb_release“的结果创建一个JSON文件

我所做的:

代码语言:javascript
复制
if [ -x "$(command -v lsb_release)" ]; then
    lsb_release -a  | jq  --raw-input 'split("\t") | { (.[0]) : .[1] }' > ubuntu_release.json
fi

结果是

代码语言:javascript
复制
{
  "Distributor ID:": "Ubuntu"
}

{
  "Description:": "Ubuntu 20.04.3 LTS"
}

{
  "Release:": "20.04"
}

{
  "Codename:": "focal"
}

但我想知道结果

代码语言:javascript
复制
[
    {
      "Distributor ID:": "Ubuntu"
    },
    {
      "Description:": "Ubuntu 20.04.3 LTS"
    },
    {
      "Release:": "20.04"
    },
    {
      "Codename:": "focal"
    }
]

有人能帮我吗?)

EN

回答 1

Stack Overflow用户

发布于 2022-04-27 06:24:08

过滤器

代码语言:javascript
复制
reduce (inputs / ":\t") as [$key, $value] ({}; .+{($key): $value})

输入

代码语言:javascript
复制
Distributor ID: Ubuntu
Description:    Ubuntu 20.04.3 LTS
Release:    20.04
Codename:   focal

输出

代码语言:javascript
复制
{
  "Distributor ID": "Ubuntu",
  "Description": "Ubuntu 20.04.3 LTS",
  "Release": "20.04",
  "Codename": "focal"
}

请注意,来自$key$valueinputs的每一行都是由reduce处理和组合的。

演示

https://jqplay.org/s/ZBvKf6vQ0F

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70804610

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档