shell 脚本实现行处理(sed、head、tail)

文本的行处理,在文本处理中至关重要,现遇到问题,去除文本末尾2行的数据。现将其相关的行处理方法,做简单的总结:

sed实现显示行:
sed -n '1'p filename   // 显示filename第一行
sed -n '$'p filename   // 显示filename最后一行
sed -n '1,3'p filename  // 显示filename的第1行至第3行
sed -n '3,$'p filename   // 显示filename的第3行至最后一行
sed -n '/name/'p filename   // 显示匹配name字符的行
sed -n '/.*ing/'p filename   // 显示结尾为ing字符的行


sed实现删除行:
sed -i '1'd filename   // 删除filename文件的第一行
sed -i '1,5'd filename   // 删除filename文件的第1行至5行
sed -i '$'d filename    // 删除filename文件的最后一行
sed -i '3,$'d filename   // 删除filename文件的第3行至最后一行

那么问题来了,在实际的需求中,不仅文件的前几行可能是不必要的数据,文件的后几行,也不需要。

如果删除文件的最后3行,怎么办?
实现思路:
利用head命令,显示去除行后的内容,并将其定位到其他新的文件。
head命令:
head -n -2 filename > newfilename
如果需要保证文件名的一致性,可以用mv操作,进行文件名的修改。
mv newfilename filename


巧记:head命令可以简单记为:从头开始,-n代表显示行数(和sed命令、tail命令一致),后面的数字代表行号。此处2和+2一样,都代表第二行,-2代表倒数第2行。
上面命令的意思是:从头开始,一直显示到倒数第二行之前。

补充:
tail命令:

tail -n -2 filename > newfilename 
以上tail命令代表从末尾开始,显示到倒数第2行之后(包括倒数第2行)

猜你喜欢

转载自blog.csdn.net/adayan_2015/article/details/81165549