在匹配模式之后将行拆分为下一行

在匹配模式之后将行拆分为下一行

在下面显示的输入文件中,我试图找到该字符串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_typesubst\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 "~$/}替换将缩进)。

https://raku.org

相关内容