问:
有没有一种“规范”的方式来做到这一点?我一直在使用 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