- 用awk 打印整个test.txt (以下操作都是用awk工具实现,针对test.txt
[root@centos001 ~]# awk -F ':' '{print $0}' test.txt
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
$0表示打印所有
- 查找所有包含 ‘bash’ 的行
[root@centos001 ~]# awk '/bash/' test.txt
root:x:0:0:root:/root:/bin/bash
user1:x:1000:1000::/home/user1:/bin/bash
aming:x:1001:1007::/home/aming:/bin/bash
awei:x:1002:1002::/home/awei:/bin/bash
- 用 ‘:’ 作为分隔符,查找第三段等于0的行
[root@centos001 ~]# awk -F ':' '$3==0' test.txt
root:x:0:0:root:/root:/bin/bash
- 用 ‘:’ 作为分隔符,查找第一段为 ‘root’ 的行,并把该段的 ‘root’ 换成 ‘toor’ (可以连同sed一起使用)
[root@centos001 ~]# awk -F ':' '$1==root' test.txt | sed 's/root/toor/'
[root@centos001 ~]# awk -F ':' '$1=="root"' test.txt | sed 's/root/toor/'
toor:x:0:0:root:/root:/bin/bash
第一段没有正确输出是因为没有加双引号,==是精确匹配,不加双引号就会被认为是数字
- 用 ‘:’ 作为分隔符,打印最后一段
[root@centos001 ~]# awk -F ':' '{print $NF}' test.txt
/bin/bash
/sbin/nologin
NF表示分隔符分隔后一共有多少段
- 打印行数大于20的所有行
[root@centos001 ~]# awk -F '#' 'NR>20' test.txt
chrony:x:997:995::/var/lib/chrony:/sbin/nologin
user1:x:1000:1000::/home/user1:/bin/bash
。。。。。。。。。。。。。。。。。。
[root@centos001 ~]# awk 'NR>20' test.txt
chrony:x:997:995::/var/lib/chrony:/sbin/nologin
user1:x:1000:1000::/home/user1:/bin/bash
第二个为参考答案,所以 前面的#和-F是可以不用加的。注意区分NF与NR的区别
NR为行号
- 用 ‘:’ 作为分隔符,打印所有第三段小于第四段的行
[root@centos001 ~]# awk -F ':' '$3<$4' test.txt
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
- 用 ‘:’ 作为分隔符,打印第一段以及最后一段,并且中间用 ‘@’ 连接 (例如,第一行应该是这样的形式 'root@/bin/bash‘ )
[root@centos001 ~]# awk -F ':' '{print $1 "@" $NF}' test.txt
root@/bin/bash
bin@/sbin/nologin
9.用 ‘:’ 作为分隔符,把整个文档的第四段相加,求和
[root@centos001 ~]# awk -F ':' '{(tot=tot+$4)}; END {print tot}' test.txt
11797
(tot=tot+$4)是一个循环,表示每一次循环都会把第三段的值相加;因为tot这个值不存在,所以这里就是0+$3,在下一个就是$3加下一段的$3,以此类推