本文共 3635 字,大约阅读时间需要 12 分钟。
awk程序组成: pattern { action statements }
echo "$(df -h)" | awk '{ if (NR != 1 ) print $0}' # 正确echo "$(df -h)" | awk '(NR != 1 ) {print $0}' #正确 echo "$(df -h)" | awk 'if (NR != 1 ) {print $0}' #错误 1 2 3
pattern && pattern
模式之间可以进行与操作echo “(df -h)" | awk ' (NR != 1 && NR <= 2) { print(df -h)" | awk ' (NR != 1 && NR <= 2) { print0}’
pattern || pattern
模式之间可以进行或操作运算符 | 含义 |
---|---|
(…) | 组 |
$ | 字段引用 |
++ – | 自增/自减 |
| 一元加,减和逻辑非 |
| 乘法 除法 模 |
| 加,减 |
space | String concatenation. |
< > <= >= != == | 关系运算符 |
~ !~ | 匹配正则表达式和不匹配正则表达式 |
in | 数组成员检测 |
&& | 逻辑与 |
?: | C条件表达式 |
还有逻辑或 ||(markdown语法转义有问题,所以泻在这列。。。); * | |& *—— Piped I/O for getline, print, and printf.
变量 | 含义 |
---|---|
$0 | 完整的输入记录。 |
ARGC | 命令行参数的数目。 |
ARGIND | 命令行中当前文件的位置(从0开始算)。 |
ARGV | 包含命令行参数的数组。 |
BINMODE | |
CONVFMT | 数字转换格式(默认值为%.6g) |
ENVIRON | 环境变量关联数组。 |
ERRNO | 最后一个系统错误的描述。 |
FIELDWIDTHS | 字段宽度列表(用空格键分隔)。 |
FILENAME | 当前文件名。 |
FNR | 同NR,但相对于当前文件。 |
FS | 字段分隔符(默认是任何空格)。 |
IGNORECASE | 如果为真,则进行忽略大小写的匹配。 |
LINT | |
NF | 当前记录中的字段数。 |
NR | 当前记录数(即当前行,每处理完一条记录,NR值+1) |
OFMT | 数字的输出格式(默认值是%.6g)。 |
OFS | 输出字段分隔符(默认值是一个空格)。 |
ORS | 输出记录分隔符(默认值是一个换行符)。 |
PROCINFO | |
RLENGTH | 由match函数所匹配的字符串的长度。 |
RS | 记录分隔符(默认是一个换行符)。 |
RT | |
RSTART | 由match函数所匹配的字符串的第一个位置。 |
RLENGTH | |
SUBSEP | 数组下标分隔符(默认值是\034)。 |
TEXTDOMAIN |
if (condition) statement [ else statement ]
while (condition) statement
do statement while (condition)for (expr1; expr2; expr3) statement
for (var in array) statement函数 | 功能 |
---|---|
system() | 系统命令调用。eg: eawk ‘{system(“date”)}’ |
length() | 计算字符长度。 eg: awk ‘{if(NR==1){len=length(NF);printNF);printNF”=”len}}’ /var/log/cron |
sub() | sub (regular expression, substitution string):如果匹配正则表达式,则用substitution string替换匹配的字符串(没有target string时,则直接匹配$0中的字符串,我一般都是操作某个字段的)。2. sub (regular expression, substitution string, target string):对于target字符串,如果匹配正则表达式,则用substitution string替换到匹配的字符串,并返回替换数 |
注意,sub返回的是第一次匹配
# 没有target的情况下匹配IP。[yantao@yantao ~]$ ifconfig | awk '/inet/ {sub(/addr:/,"");ip=$2;print ip}'10.1.1.4642.51.169.10111.7.132.211127.0.0.1# [yantao@yantao ~]$ ifconfig | awk '/inet/ {sub(/addr:/,"",$2);print}' inet 10.1.1.46 Bcast:10.1.1.255 Mask:255.255.255.0inet 42.51.169.10 Bcast:42.51.169.255 Mask:255.255.255.0inet 111.7.132.211 Bcast:111.7.132.223 Mask:255.255.255.224inet 127.0.0.1 Mask:255.0.0.0 1 2 3 4 5 6 7 8 9 10 11 12 13
[root@logan ~]# df -hFilesystem Size Used Avail Use% Mounted on/dev/sda1 9.7G 5.5G 3.7G 61% /tmpfs 491M 4.0K 491M 1% /dev/shm/dev/sda3 18G 8.8G 8.4G 52% /usr/local/usr/local/src/iso/CentOS-6.8-x86_64-bin-DVD1.iso 3.7G 3.7G 0 100% /iso/CentOS-6.8[root@logan ~]# echo "$(df -h)" | awk '(NR != 1 && $6 != "/dev/shm") && /[/a-z]+$/ {print $6}'//usr/local 1 2 3 4 5 6 7 8 9 10
这里用到了模式之间的与以及(parrten)模式
[root@logan ~]# echo "$(df -h)" | awk '/[a-z/]+$/ { if(NR != 1 && $6 != "/dev/shm"){print $6}}' //usr/local 1 2 3
。。。。。awk持续更新这篇文章持续更新。会增加更多的示例。错误之处请指正