我有一个包含数百万行的文件.我也有一个行号列表,几十万个是非顺序的,没有模式.我想用行号列表提取文件的行.如何在Linux中有效地实现这一目标?
解决方法:
如果您在文件中有行号列表,那么使用awk可以执行以下操作-
awk 'NR==FNR { a[$1];next } (FNR in a)' line_number_list.txt bigfile.txt
测试:
$cat bigfile.txt
line1
line2
line3
line4
line5
line6
line7
line8
line9
line10
$cat line_number_list.txt
1
2
4
5
8
9
$awk 'NR==FNR { a[$1];next } (FNR in a)' line_number_list.txt bigfile.txt
line1
line2
line4
line5
line8
line9