1、awk介绍
全称:Ahc weinberger Kernaighan 三个人的首字母缩写
GNU计划80年代发起的开源计划,awk就是GNU带过来的软件程序。
默认情况下,三个工具都不去编辑源文件(grep,sed,awk)
awk报告生成器:
通过模式匹配以及自己本身的语言格式,来获取并输出客户所需要的内容;
示例:获取系统上面用户id大于等于1小于等于500的用户名和用户ID
awk -F: '{if($3>=1&&$3<=500){print $3}}' /etc/passwd
使用格式化输出的意义:
awk -F: -v OFS=":" 'BEGIN{printf"username uid \n========================\n"}{if($3>=1&&$3<=500){printf"用户名:%-10s UID:%-10d\n",$1,$3}}' /etc/passwd
2、awk工作原理
文本文件的多行内容放到awk编辑器里进行操作,默认以空格为分割符,进行分割,awk的内置参数会对分割的内容进行分配,行处理。
3、awk的用法
awk[option] ... 'program' file ...
1.program必须使用单引号
2.多条program语句必须使用大括号包含起来,可以并列,可以嵌套
4、awk的常见option
-F 指定分隔符
awk -F[/:] '{print $3,$5,$7}' /etc/passwd
其中[ ]内表示多个字符中的任意一个
-v 因为awk是一种语言编译器,能自己定义变量,同时也有内置变量
手动指定变量参数
awk -v a="a/b" '{print a}' a.txt
给a赋值,打印a这个变量
1、a是自定义变量 -v FS=":"
2、在awk中调用变量,不用加$符号
扩展:
了解cut与awk的区别:
5、awk的语法格式
1.print
默认输出(在屏幕上输出,并没有存储)
在awk里没有保存命令,我们可以关联别的命令来保存
awk '{a="a/b";print a}' a.txt | tee a.bak
awk '{a="a/b";print a}' a.txt > a.bak.1
2.printf
格式化输出
printf"字符串",$a,$b【仅仅只有顺序关系】
格式符:
%s 字符串
%d %i 数值
%e,%E 科学计算数值
%f 浮点
%c ACSii码值
%u 无符号整数
%% 逃逸符 只显示%自己
修饰符:
默认右对齐
-代表左对齐
%5.4f(5:所占位数,4:所取小数位)
awk '/^UUID/{printf"被挂载文件是:%-20s 挂载点:%-10s 文件系统是:%-10s\n",$1,$2,$3}' /etc/fstab
注意:这里提到了地址定界 /^UUID/
3.变量(内置变量、环境变量)
内置变量:环境变量(bash)(env、set -C +C)
awk语言所支持的变量
FS 定义输入分割符变量
OFS 定义输出分隔符的变量
NF ($NF 分割以后最后一列的变量)
*变量引用的时候,不用加$,
NF定义分隔以后的参数个数
NR 定义文件的行数,定义多个文件的,文件的行号叠加
FNR 文件只计算自己的行号
awk '{print NR}' /etc/passwd /etc/fstab
awk '{print FNR}' /etc/passwd /etc/fstab
FILENAME 存储文件的名字
awk '{print FILENAME}' /etc/passwd 把文件名打印N次,N文件的行数
awk 'BEGIN{print FILENAME}' /etc/passwd BEGIN语句只在循环开始的时候,执行一次
ARGC 整个命令的段数
ARGV 数组,用来调取命令中指定的字段
awk 'BEGIN{print ARGC}' /etc/passwd
awk 'BEGIN{print ARGV[3]}' /etc/passwd
RS 指定换行符 \n 可以指定新的换行符,不影响本身的换行符
awk -v RS=" " '{print $0}' /etc/passwd
ORS 输出的时候指定换行符 将默认换行符替换为指定字符
awk -v ORS="@" '{print}' /etc/passwd
自定义变量 -v 变量=值
在后面program中去调用自定义变量时,直接使用即可
或者将“变量=值”语句直接写在program里也行