需要在标记
中匹配模式之前和之后删除< mds:insert>
< attributeValues>
< AttrNames
< Item Value="MyContact_c"/>
< /AttrNames>
< /attributeValues>
< /mds:insert>
使用
sed -i -n '/MyContact_c/{s/.*//;x;d;};x;p;${x;p;}' $file
只删除匹配模式前后的行,需要删除mds中的所有内容:insert tag ...任何指针都会有所帮助。
答案 0 :(得分:0)
它不是sed
,但是ex
使用您发布的$file
文件内容的代码段为kitsune:~$ printf '%s\n' 'set ic
1;/="MyContact_c"/<|?<mds:insert?+;/<\/mds:insert>/-d
%p' | ex -s $file
:
<mds:insert>
</mds:insert>
输出:
'set ic
g/="MyContact_c"/<|?<mds:insert?+;/<\/mds:insert>/-d
%p'
这将在删除该部分的第一个实例后打印文件的剩余部分。如果要为所有实例完成此操作,命令行将如下所示:
ex
如果要对多个文件执行此操作,可以在shell脚本的for循环中使用它。如果你做这样的事情,你自然会想要一个备份副本,所以如果你打算覆盖它,请确保在更改之前复制该文件。
顺便说一句,如果您曾经使用过Vim甚至vi,这些命令都会用于保存,退出等。值得将kitsune:~% printf '%s\n%s\n%s\n' 'set ic' '1;/="MyContact_c"/<|?<mds:insert?+;/<\/mds:insert>/-d' '%p' | ex -s $file
添加到您的知识工具箱中。{/ p >
修改强>
C Shell用户不能按原样使用这些命令,因为它们包含引用的换行符,这在C shell中是不允许的。相反,您可以像这样修改第一个命令:
{{1}}
您可以使用其他字符串执行相同的操作。
免责声明:我自己不是C shell用户,所以可能有更好的方法,但我不知道。
答案 1 :(得分:0)
以下是在sed中执行此操作的一种方法:
sed -e ':a' -e '/ mds:insert/!{p;d;}' -e 'N;/\/mds:insert/{/MyContact_c/!p;d;};ba' filename
修改
你和我可能正在使用不同版本的sed或其他东西。我们来试试吧:
sed -e '/ mds:insert/!{p;d;}' filename
它不会做任何有趣的事情,但我想知道它是否会产生错误。
答案 2 :(得分:0)
以下是使用awk
awk '{a[NR]=$0} /MyContact_b/ {f=NR} END {for (i=1;i<=NR;i++) if (i+2<f || i-2>f || !f) print a[i]}' file
< mds:insert>
< /mds:insert>
如果发现它,它会跳过前面的两行和pattern
之后的两行。