问题:
有没有一种“规范”的方式来做到这一点?我一直在使用 head -n | tail -1
,它可以做到这一点,但我一直想知道是否有一个Bash工具,专门从文件中提取一行(或一段行)。
所谓“规范”,我指的是一个主要功能就是这样做的程序。
回答:
有一个可供测试的文件,内容如下:
使用 sed
命令,要打印第 20 行,可写为
sed -n '20'p file.txt
sed -n '20p' file.txt
测试截图如下:
要打印第 8 到第 12 行,则可用命令
sed -n '8,12'p file.txt
如果要打印第8、9行和第12行,可用命令
sed -n '8p;9p;12p' file.txt
对于行数特大的文件,为了提高处理速度,可采用类似如下命令
sed '5000000q;d' file.txt
tail -n+5000000 file.txt | head -1
需要关注处理性能的伙伴可以在上述命令前加上 time
再对大文件进行测试对比。
其他可实现相同效果的命令工具还有 cut, awk, perl 等:
cut -f23 -d$'\n' file.txt
awk 'NR == 23 {print; exit}' file.txt
perl -wnl -e '$.== 23 && print && exit;' file.tx
参考:
- stackoverflow question 6022384
- man sed
- man tail
- man cut
- man awk
相关阅读:
- 带有-i选项的sed命令在Linux上执行成功,但在MacOS上失败了
- 为什么我不能在脚本中使用“cd“来更改目录
- 2>&1是什么意思
- 如何使用bash脚本并行运行多个程序
- 为什么要使用xargs命令
- xargs命令用法实例