在下面显示的输入文件中,我试图找到该字符串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
答案1
我不清楚你的要求,但也许你想要:
sed 's/\([[:upper:]][[:alpha:]_]*\)[[:space:]]\{1,\}\(job_type:\)/\1\
\2/g'
或者:
perl -Mopen=locale -pe 's/\b\p{Lu}\w*\K\s+(job_type:)/\n$1/g'
答案2
我会使用 GNU 做类似的事情sed
:
sed '/insert_job/s/job_type/\njob_type/'
第一部分/insert_job/
与进行替换之前的一行相匹配。如果找不到“insert_job”(或您喜欢的任何正则表达式),它将不会进行替换。
答案3
使用GNUsed
$ sed '/ \+\(insert_job.*\)\(job_type:.*\)/s//\1\n\2/' input_file
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
答案4
使用乐(以前称为 Perl_6)
假设要修改的行都包含至少 4 个以空格分隔的“列”(少于 4 个“列”的行将不修改地返回):
raku -ne 'my @a = .words; @a.elems >= 4 ?? put @a[0..1], "\n", @a[2..*] !! put @a;'
上面假设输入中没有字符串模式,只有适当数量的空格分隔words
(即列)。对于匹配行,返回前 2 列,然后是换行符,然后是其余列(OP 提供示例输入,其中字符串job_type
从第三列开始)。
但是,如果您想使用正则表达式并搜索字符串模式,Raku 可以为您提供支持(使用subst
运算符)。下面,Raku 在字符串开头和字符串结尾零宽度断言(锚点)/ ^ ... $ /
之间搜索 8 个正则表达式原子。一旦匹配,Raku 的捕获标记将用于丢弃匹配中之前的所有内容。然后在替换的一半中,换行符被连接到匹配变量并返回。^
$
<(
job_type
subst
\n
~
$/
raku -ne '.subst(/^ insert_job\: \s .+? \s <(job_type\: \s \w* \s*? $/, {"\n"~$/} ).put;'
输入示例:
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
请注意,OP 尚未明确所有输出是否应左对齐(零前导空白字符)。上面的第一个答案是左对齐的,但是很容易trim
甚至缩进job_type
输出中以 开头的所有行(例如,在第二个答案中使用{"\n "~$/}
替换将缩进)。