我的输入
1
abc
1cde
efg
xxx
1
abc
pattern1
pattern2
efg
xxx
1
abc
cde
efg
xxx
我的预期输出(从1打印,包含pattern1和2):
1
abc
pattern1
pattern2
efg
xxx
我这样做:
sed -n '/^1/ {x;/pattern1/ {N;/\n.*pattern2/p};d} $/^1/ {h;/pattern1/ {N;/\n.*pattern2/p};d}}H' My file
BTW我的文件是一个非常大的文件,请给我一个可以快速完成的方法。 非常感谢。
答案 0 :(得分:3)
sed适用于s/old/new/
- 这就是全部。对于其他任何你应该使用awk。
看起来您的预期输出实际上无法从您的示例输入中生成,所以它是猜测和未经测试的,因为我们没有具体的测试对象,但听起来您可能想要:
awk -v RS= -v ORS='\n\n' '/pattern1/ && /pattern2/' file