Linux报告生成器工具awk
awk:根据输入的信息格式化后显示出来
1.1、awk基本用法
awk [options] 'script' file1,file2,....
或 awk [options] 'PATTERN [ACTION]' file1,file2....
示例:awk '{print $1}' test.txt
options:
-F:定义分隔符
示例awk -F: 以冒号为分隔符
1.2、awk内置变量
(1)记录变量
FS:设置默认字段分隔符 示例awk -F: 以冒号为分隔符
RS:设置默认记录分隔符
OFS:设置默认输出字段分隔符
ORS:设置默认输出记录分隔符
(2)数据变量
NR:awk命令所处理的记录(行)数,若有多个文件,这个记录数为其总数
FNR:awk正处理的记录(行)是当前这个文件中被总共处理的记录(行)数
NF:当前记录(行)的字段个数
ARGV:数组,保存命令行本身这个字符串
ARGC:awk命令的参数
FILENAME:awk命令所处理的文件的名称
ENVIRON:当前shell环境变量及其值的关联数组
1.3、print的使用格式
print item1,item2,...
各项目之间使用逗号隔开,输出则以空格隔开
1.4、printf
与print不同之处在于,printf需要指定format
使用格式:printf format,item1,item2...
format格式的指示符都是以%开头,后跟一个字符
%c:显示字符的ASCII码
%d,%i:十进制整数
%f:显示浮点数
%s:显示字符串
%%:显示%自身
格式修饰符
N:显示宽度
-:左对齐
+:显示数值符号
示例:awk -F: '{PRINTF "%-15S" %i\n,$1,$3}' /etc/passwd
1.5、awk的操作符
(1)算数操作符
-x:负值
+x:转换为数值
(2)赋值操作符
=
+=
%=
(3)比较操作符
==:相等
!=:不等
(4)表达式间的逻辑关系符
&&
||
1.6、awk的模式pattern
使用格式:awk 'pattern{action}' file1 file2
常见的模式类型
1 正则表达式,/pattern/
2 表达式,其中~和!~表示匹配与不匹配
3 指定匹配范围,格式为pattern1,pattern2;从匹配pattern1开始到匹配到 pattern2结束
4 BEGIN/END:特殊模式,仅在awk命令执行前运行一次或结束前运行一次
5 Empty(空模式):即匹配任意行
常见的acton
表达式
控制语句for等
if(condition)(then...)else{[...]}
while(condition){语句1,语句2....}
do{语句1,语句2....}while(condition)
for(condition){语句1,语句2....}
switch(表达式){case 值或正则表达式:语句1...default:语句1...}
复合语句
输入输出语句
break和continue常用于循环或case语句中
next:提前结束对本行文本的处理,并接着处理下一行
示例:显示其ID好为奇数的用户
awk -F:'{if($3%2==0) next;print $1,$3}' /etc/passwd
1.7、awk中使用数组
array[数组下标或索引]
netstat -ant | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'
每出现一被/^tcp/模式匹配到的行,数组S[$NF]就加1,NF为当前匹配到的行的最后一个字段,
此处用其值做为数组S的元素索引;
1.8、awk的内置函数
split:分割函数
使用方法split(string,A,pattern):将string按pattern进行分割,存储为A[1],A[2]
length([string])
返回string字符串中字符的个数;
substr(string, start [, length])
取string字符串中的子串,从start开始,取length个;start从1开始计数;
system(command)
执行系统command并将结果返回至awk命令
systime()
取系统当前时间
tolower(string)
将string中的所有字母转为小写
toupper(s)
将s中的所有字母转为大写
十一、用户自定义函数
自定义函数使用function关键字。格式如下:
function F_NAME([variable]) 定义自定义函数
{
statements
}
F_NAME:使用自定义函数
函数还可以使用return语句返回值,格式为“return value”。