cat /etc/passwd > /root/test.txt
1、用awk 列印整個test.txt (以下操作都是用awk工具實作,針對test.txt)
awk '{print $0}' test.txt
2、查找所有包含 ‘bash’ 的行
awk '/bash/ {print $0}' test.txt
3、用 ‘:’ 作為分隔符,查找第三段等于0的行
awk -F ':' '$3==0' test.txt
4、用 ‘:’ 作為分隔符,查找第一段為 ‘root’ 的行,并把該段的 ‘root’ 換成 ‘toor’ (可以連同sed一起使用)
awk -F ':' '/root/' test.txt | sed 's#root#toor#g'
5、用 ‘:’ 作為分隔符,列印最後一段
awk -F':' '{print $NF}' test.txt
6、列印行數大于20的所有行
awk 'NR>20' test.txt
7、用 ‘:’ 作為分隔符,列印所有第三段小于第四段的行
awk -F ':' '$3<$4' test.txt
8、用 ‘:’ 作為分隔符,列印第一段以及最後一段,并且中間用 ‘@’ 連接配接 (例如,第一行應該是這樣的形式 'root@/bin/bash‘ )
awk -F':' '{print $1"@"$NF}' test.txt
9、用 ‘:’ 作為分隔符,把整個文檔的第四段相加,求和
awk -F ':' '{(sum+=$4)};END{print sum}' test.txt
練習2:列印某行到某行之間的内容
例如:有個檔案test的内容如下:
ert
fff
[abcfd]
123
324
444
[rty]
fgfgf
怎麼能截取
這一部分出來呢?
答案: sed -n '/[abcfd]/,/[rty]/p' test
本文轉自 jiekegz 51CTO部落格,原文連結:http://blog.51cto.com/jacksoner/2043899