AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题 / 77956650
Accepted
Ahmad Ismail
Ahmad Ismail
Asked: 2024-02-08 01:05:09 +0800 CST2024-02-08 01:05:09 +0800 CST 2024-02-08 01:05:09 +0800 CST

使用正则表达式和 jq 替换 json 的部分值

  • 772

我有一个如下所示的 json:

[
  {
    "name": "architecture-design-detailed",
    "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed",
    "paths": [],
    "group": "",
    "enabled": true
  },
  {
    "name": "architecture-design-detailed-engineering",
    "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed-engineering",
    "paths": [],
    "group": "",
    "enabled": true
  }
]

如果名字是architecture-design-detailed,

  • 将名称更改为new_name_here

  • 用 new_name_here 替换 rootPath 的最后一部分(这是架构设计详细的,在最后一个 / 之后)。

所以预期的输出是:

[
  {
    "name": "new_name_here",
    "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/new_name_here",
    "paths": [],
    "group": "",
    "enabled": true
  },
  {
    "name": "architecture-design-detailed-engineering",
    "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed-engineering",
    "paths": [],
    "group": "",
    "enabled": true
  }
]

到目前为止我想到的是:

jq 'map(if .name == "architecture-design-detailed" then .name = "new_name_here" else . end)'

但不明白如何替换 rootPath 的最后一部分。我认为我们必须使用subor gsub。但不明白如何。

jq
  • 3 3 个回答
  • 33 Views

3 个回答

  • Voted
  1. Best Answer
    0stone0
    2024-02-08T01:13:54+08:002024-02-08T01:13:54+08:00

    您可以使用split("/")转换rootPath为数组,然后将最后一个索引 ( .[-1]) 设置为new_name,然后将join("/")它们重新组合在一起。

    我们使用|=insidemap()来更新由 找到的对象select(),然后.name根据rootPath需要进行覆盖。

    map(select(.name == "architecture-design-detailed") 
        |= ( 
            .name = "new_name",
            .rootPath = (.rootPath | split("/") | .[-1] = "new_name" | join("/"))
        ) 
    )
    
    [
      {
        "name": "new_name",
        "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/new_name",
        "paths": [],
        "group": "",
        "enabled": true
      },
      {
        "name": "architecture-design-detailed-engineering",
        "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed-engineering",
        "paths": [],
        "group": "",
        "enabled": true
      }
    ]
    

    JqPlay演示

    • 1
  2. Hira Arif
    2024-02-08T01:16:08+08:002024-02-08T01:16:08+08:00

    为了使用 jq 实现您的目标,当名称匹配“architecture-design-detailed”时,您确实需要使用 sub 函数来替换 rootPath 的最后部分。除了更改名称之外,您的 jq 过滤器还需要扩展以有条件地修改 rootPath。

    map(
      if .name == "architecture-design-detailed" then
        .name = "new_name_here" |
        .rootPath |= sub("/architecture-design-detailed$"; "/new_name_here")
      else
        .
      end
    )
    

    输出:

    [
      {
        "name": "new_name_here",
        "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/new_name_here",
        "paths": [],
        "group": "",
        "enabled": true
      },
      {
        "name": "architecture-design-detailed-engineering",
        "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed-engineering",
        "paths": [],
        "group": "",
        "enabled": true
      }
    

    ]

    • 1
  3. pmf
    2024-02-08T03:55:29+08:002024-02-08T03:55:29+08:00

    这是另一种方法,它通过使用 右修剪旧名称来立即.name, .rootPath更新所选项目匹配的两个字段,然后使用 添加新名称:.name == $fromrtrimstr($from)+ $to

    jq --arg from 'architecture-design-detailed' --arg to 'new_name_here' '
      map((select(.name == $from) | .name, .rootPath) |= rtrimstr($from) + $to)
    '
    
    [
      {
        "name": "new_name_here",
        "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/new_name_here",
        "paths": [],
        "group": "",
        "enabled": true
      },
      {
        "name": "architecture-design-detailed-engineering",
        "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed-engineering",
        "paths": [],
        "group": "",
        "enabled": true
      }
    ]
    
    • 0

相关问题

  • 尝试选择一个不包含 using jq 的值

  • 有条件地从两个不同字段之一提取值

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    为什么这个简单而小的 Java 代码在所有 Graal JVM 上的运行速度都快 30 倍,但在任何 Oracle JVM 上却不行?

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    何时应使用 std::inplace_vector 而不是 std::vector?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Marko Smith

    我正在尝试仅使用海龟随机和数学模块来制作吃豆人游戏

    • 1 个回答
  • Martin Hope
    Aleksandr Dubinsky 为什么 InetAddress 上的 switch 模式匹配会失败,并出现“未涵盖所有可能的输入值”? 2024-12-23 06:56:21 +0800 CST
  • Martin Hope
    Phillip Borge 为什么这个简单而小的 Java 代码在所有 Graal JVM 上的运行速度都快 30 倍,但在任何 Oracle JVM 上却不行? 2024-12-12 20:46:46 +0800 CST
  • Martin Hope
    Oodini 具有指定基础类型但没有枚举器的“枚举类”的用途是什么? 2024-12-12 06:27:11 +0800 CST
  • Martin Hope
    sleeptightAnsiC `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它? 2024-11-09 07:18:53 +0800 CST
  • Martin Hope
    The Mad Gamer 何时应使用 std::inplace_vector 而不是 std::vector? 2024-10-29 23:01:00 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST
  • Martin Hope
    MarkB 为什么 GCC 生成有条件执行 SIMD 实现的代码? 2024-02-17 06:17:14 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve