我有一个文件文件1.txt如下所示:
line 1 file 1
line 2 file 1
line 3 file 1
line 4 file 1
第二个文件文件2.txt如下所示:
line 1 file 2
line 2 file 2
line 3 file 2
line 4 file 2
line 5 file 2
我想纠正一个单行命令(最好使用 sed),它将从第二个文件 (file2.txt) 获取第 2-4 行,并将第 3 行之后的这些行添加到第一个文件(file1.txt) 中。
所以我的输出应该如下所示:
line 1 file 1
line 2 file 1
line 3 file 1
line 2 file 2
line 3 file 2
line 4 file 2
line 4 file 1
为了从第二个文件中获取第 2-4 行,我可以使用:
sed -n '2,4p' file2.txt
为了在文件 3 中插入第 1 行之后的行,我可以像下面这样使用:
sed '4i<What to insert here>' file1.txt
但是如何将这两个操作结合起来呢?
同意另一个回答者的观点,这是awk
的工作,可以用sed
来完成。
除了著名的s
命令之外,sed
还提供了各种奇怪的命令,并且有一个用于GNU sed的e
执行命令。在你给出了问题中的所有部分之后,这里是如何组合你的想法:
sed '4 e sed -n 2,4p file2.txt' file1.txt
ed
是一个编辑器,可以就地保存文件:
ed file1.txt <<END
3a
$(sed -n 2,4p file2.txt)
.
wq
END
GNU awk 可以就地保存:
gawk -i inplace -v text="$(sed -n 2,4p file2.txt)" '1; NR==3 {print text}' file1.txt
您可以使用 awk:
awk 'FNR==NR{if (FNR>=2 && FNR <=4) s=(s==""?$0:s RS $0); next} FNR==4{print s} 1' f2 f1
line 1 file 1
line 2 file 1
line 3 file 1
line 2 file 2
line 3 file 2
line 4 file 2
line 4 file 1
解释:
NR == FNR { # While processing the 2nd file
if (FNR>=2 && FNR <=4) # for line # 2 to 4
s=(s==""?$0:s RS $0 # store each line in variable s separated by newline
next
}
FNR==4 { # while processing the 1st file if line # is 4
print s # print stored text from variable s
}
1 # default action to print each line from file1
这是 AWK 的工作,但使用 sed 这样的东西可以在 bash 中工作:
sed '3r '<(sed -n '2,4p;5q' file2) file1