文章目录
- 一、Awk 的两个特殊模式
-
- 二、Awk高级应用
- 1. if单分支语句
- 2. if双分支语句
- 3. for循环
- 4. while循环
- SHELL—— awk两个特殊模式(BEGIN 和 END)及awk高级应用(条件判断、循环)
一、Awk 的两个特殊模式
- BEGIN 和 END,BEGIN 被放置在没有读取任何数据之前
- END 被放置在所有的数据读取完成以后执行
- 体现如下:
- BEGIN{}: 读入第一行文本之前执行的语句,一般用来初始化操作
{}: 逐行处理
END{}: 处理完最后以行文本后执行,一般用来处理输出结果
实例:
文件开头加XWPHSA,末尾加XWPHCA ,打印行号和内容
[root@server19 mnt]# awk -F: 'BEGIN {print "XWPHSA"} {print NR;print} END {print "XWPHCA"}' /etc/passwd
统计文本总字段个数
[root@server19 mnt]# vim test.txt
hui hui XX
XX
XX ni Xx
[root@server19 mnt]# awk 'BEGIN{i=0}{i+=NF}END{print i}' test.txt
7
二、Awk高级应用
1. if单分支语句
统计登录shell为bash的用户
[root@server19 mnt]# awk -F: 'BEGIN{i=0}{if($7~/bash$/){i++}}END{print i}' /etc/passwd
2
1
2
统计/etc/passwd下uid小于500的用户个数
[root@server19 mnt]# awk -F: 'BEGIN{i=0}{if($3<500){i++}}END{print i}' /etc/passwd
31
1
2
2. if双分支语句
统计uid小于等于500和大于500的用户个数
[root@server19 mnt]# awk -F: 'BEGIN{i=0;j=0}{if($3<=500){i++}else{j++}}END{print i,j}' /etc/passwd
31 9
3. for循环
生成1-5序列
[root@server19 mnt]# awk 'BEGIN{for(i=1;i<=5;i++){print i}}'
1
2
3
4
5
```java
[root@server19 mnt]# seq 5 ##seq命令可以直接生成
1
2
3
4
5
1
2
3
4
5
6
7
8
9
10
11
12
13
4. while循环
语法一:
[root@test ~]# awk 'i=1 {} BEGIN {while (i<3) {++i;print i}}' test.txt
1
2
3
[root@test ~]#
语法二:
[root@test ~]# awk 'BEGIN {do {++i;print i} while (i<3)}' test.txt
1
2
3
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)