Bash :如何在Unix的文件中插入一定行之后的文本块



我有一个文件文件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

相关内容

  • 没有找到相关文章

最新更新