json - 使用 SED 命令检索 JSON 对象键值

标签 json ubuntu sed

我有一个来自 curl 命令的 JSON,如下所示,它存在于 output.txt 文件中。我想找回 JIRA 状态,这里是“进行中”

{
     "self": "https://jira.com/jira/rest/api/2/issue/1",
     "fields": {
        "status": {
            "self": "https://jira.com/jira/rest/api/2/status/10170",
            "description": "", 
            "name": "In Progress",
            "id": "10170" 
        }
    }
}
我有一个只能使用 sed 的限制。我试过如下它不起作用。我不确定如何导航到名称值。你能建议打印JIRA状态吗
sed -n 's|.*"fields":{"status":{"name":"\([^"]*\)".*|\1|p'  output.txt

最佳答案

您可以使用

sed -n 's/^[[:space:]]*"name": "\(.*\)",/\1/p' output.txt
# With GNU sed:
sed -n 's/^\s*"name":\s*"\(.*\)",/\1/p' output.txt
online demo
细节:
  • n - 禁止默认行输出
  • ^\s*"name":\s*"\(.*\)", - 火柴
  • ^ - 字符串开头
  • \s* - 零个或多个空格
  • "name": - 文字字符串
  • \s* - 零个或多个空格
  • " - 一个 "字符
  • \(.*\) - 一个 POSIX BRE 捕获组,匹配最多
  • 的任何文本
  • ", - 最后一次出现 ", (无论如何,它们都在目标行的末尾)。

  • \1 - 将整个匹配替换为第 1 组值
  • p - 只打印替换结果。

  • 使用 GNU sed ,您也可以使用 -z选项将文件作为单个字符串读取,然后使用更具体的模式:
    sed -z 's/.*"fields":\s*{\s*"status": {.*\s*name": "\([^"]*\)".*/\1/' output.txt
    
    this online demo .
    它的作用非常接近 this demo .

    关于json - 使用 SED 命令检索 JSON 对象键值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67836241/

    相关文章:

    linux - SED 错误 : sed -i expression

    JQuery Full Calendar with Spring MVC ..无法调用 Controller 来获取JSON对象

    java - 使用与 gson 的 csv-headers 不同的属性名称将 csv-table 映射到 json 的简单方法?

    linux - gnome中获取桌面路径的方法

    laravel - 如何在 ubuntu 18.04 上安装 laravel

    函数内部 sed 命令中的 bash 语法错误,在命令行上工作正常

    javascript - 连接没有索引 0 的 JSON 数组对象未定义

    c# - 我可以在属性中指定路径以将我的类中的属性映射到我的 JSON 中的子属性吗?

    azure - 在 Azure 应用程序网关上部署 ASP.NET 代码时出现 502 错误

    bash - 计算两个文件中数字的差异