在下面显示的输入文件中,我试图找到字符串job_type
并将其移动到下一行,如果它与 job_type 匹配。
我试过这个,但它不工作:
sed "s/[A-Z][a-z]*job_type:/\njob_type:/g"
输入:
insert_job: VAU_vaultnotification_ertgvfg_job job_type: xxx
insert_job: VAU_vaultnotification_ertgvfg_frd job_type: yyy
insert_job: VAU_vaultnotification_ertgvfg_erb job_type: SXC
job_type: CMD
insert_job: VAU_vaultnotification_ertgvfg_frd job_type: YUI
预期输出:
insert_job: VAU_vaultnotification_ertgvfg_job
job_type: xxx
insert_job: VAU_vaultnotification_ertgvfg_frd
job_type: yyy
insert_job: VAU_vaultnotification_ertgvfg_erb
job_type: SXC
job_type: CMD
insert_job: VAU_vaultnotification_ertgvfg_frd
job_type: YUI
我不清楚您的要求,但也许您想要:
或者:
我会使用 GNU 做类似的事情
sed
:第一部分
/insert_job/
在进行替换之前匹配一行。如果找不到“insert_job”(或您喜欢的任何正则表达式),它将不会进行替换。使用 GNU
sed
使用Raku(以前称为 Perl_6)
假设要修改的行都包含至少 4 个空格分隔的“列”(少于 4 个“列”的行不加修改地返回):
上面假设输入中没有字符串模式,只有适当数量的空格分隔
words
(即列)。对于匹配的行,返回前 2 列,然后是换行符,然后是剩余的列(OP 提供示例输入,其中字符串job_type
从第 3 列开始)。但是,如果您想使用正则表达式并搜索字符串模式,Raku 可以为您提供支持(使用
subst
运算符)。下面,Raku 在字符串开头和字符串结尾的零宽度断言(锚点)/ ^ ... $ /
之间搜索 8 个正则表达式原子。匹配后,Raku 的捕获标记将用于从匹配中删除之前的所有内容。然后在替换部分中,将换行符连接到匹配变量并返回。^
$
<(
job_type
subst
\n
~
$/
样本输入:
示例输出(上面的第一个代码示例):
请注意,OP 尚未明确所有输出是否应左对齐(零前导空白字符)。上面的第一个答案是左对齐的,但是很容易
trim
甚至缩进job_type
以输出开头的所有行(例如,在第二个答案{"\n "~$/}
中使用替换将缩进)。https://raku.org