天天看点

awk练习

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

本文转自 iekegz 51CTO博客,原文链接:http://blog.51cto.com/jacksoner/2043899,如需转载请自行联系原作者