AWK默认情况下,分割符为空格或者TAB,利用$NUMBER的方式进行引用字段,注意$0为整行。[root@localhost ~]# echo "this is a test." | awk '{print $1,$2 }'
this is
[root@localhost ~]#
对于ACTION中print的使用用法:
print item1,item2,item3...
要点:
各项目以,隔开,则输出时以空格隔开
可以通过 “”的形式插入字符串信息[root@localhost ~]# echo hello world | awk '{print $1"ok"$2}'
hellookworld
[root@localhost ~]#
AWK可以不用读取INPUTSTREAM的信息来直接格式化输出的。[root@localhost ~]# awk 'BEGIN {print "hello\nworld"}'
hello
world
[root@localhost ~]#
AWK可以通过选项F来指定分隔符。[root@localhost ~]# awk -F: '{print $1,$2}' /etc/passwd | head -2
root x
bin x
AWK内部支持变量,比如:
在BEGIN中可以定义:
FS 输入分割符 当然可以通过选项F来定义
OFS 输出分隔符
注意到AWK是一行行的读取文本内容,那么行与行的标志是什么?默认情况下是换行符$
其实对于AWK而言,我们完全可以自定义换行符。变量RS(record seperator ,默认是换行符,当然是输入换行符),对应的ORS是输出换行符。
NR number of input records AWK所处理的记录数 如果有多个文件,就累加
FNR AWK所处理的记录数 如果有多个文件,注意是相对于文件的
NF number of fileds 记录当前行的分片个数,显然如果我们在{print $NF}的话,打印的就是最后的一个分片内容,如果{print NF}的话,打印的是当前行的分片个数。
【注意在AWK中打印变量值是不需要加$的,在AWK中加入$的表示打印字段】[root@localhost ~]# awk -F: 'BEGIN{OFS="#"}{print $1,$2}' /etc/passwd | head -2
root#x
bin#x
[root@localhost ~]#
关于printf
需要注意,第一要指定FORMAT格式,第二PRINTF不会自动换行的
常用格式:
%d %i 10进制整数
%f 浮点数
%s 字符串
%% 显示%自身
还可以对上面的格式进行修饰:
N 宽度
- 左对齐
+ 右对齐 默认[root@localhost ~]# awk 'BEGIN{printf "%10d,%10d\n",12,13}'
12, 13
[root@localhost ~]#
[root@localhost ~]# awk 'BEGIN{printf "%-10d,%10d\n",12,13}'
12 , 13
[root@localhost ~]#
正则表达式 /regexp/ 【利用正则,过滤处理】[root@localhost ~]# awk -F: '/^z/{print $1}' /etc/passwd
zhangfengzhe
[root@localhost ~]#
表达式[root@localhost ~]# awk -F: '$3<=500&&$3>=200{print $1}' /etc/passwd
zhangfengzhe
[root@localhost ~]# awk -F: '$7~"bash$"{print $1}' /etc/passwd
root
zhangfengzhe
[root@localhost ~]# awk -F: '$NF=="/bin/bash"{print $1}' /etc/passwd
root
zhangfengzhe
[root@localhost ~]#[root@localhost ~]# awk -F: '$NF!~"/bin/bash"{print $1}' /etc/passwd
bin
daemon
BEGIN/END 特殊模式,仅在AWK命令执行前或者执行结束后运行一次[root@localhost ~]# awk -F: 'BEGIN{printf "%-20s%-10s\n","username","uid"}{printf "%-20s%-10d\n",$1,$3}' /etc/passwd
username uid
root 0
bin 1
daemon 2