我有一个包含数百万行的文件.我也有一个行号列表,几十万个是非顺序的,没有模式.我想用行号列表提取文件的行.如何在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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。