awk编辑器
工作原理
逐行读取文本,默认以空格或tab键为分隔符进行分隔,将分隔所得的各个字段保存到内建变量中,并按模式或者条件执行编辑命令。
sed与awk
- sed:命令常用于一整行的处理
- awk:比较倾向于将一行分成多个“字段”然后再进行处理
awk信息的读入也是逐条读取的,执行结果可以通过print的功能将字段数据打印显示。在使用awk命令的过程中,可以使用逻辑操作符**“&&”表示“与”、“||”表示“或”、“!”表示“非”**;还可以进行简单的数学运算,如+、-、*、/、%、^分别表示加、减、乘、除、取余和乘方。
命令格式
awk 选项 '模式或条件 {操作}' 文件 1 文件2 ……
awk -f 脚步文件 文件1 文件2 ……
awk常见的内建变量
FS | 列分隔符。指定每行文本的字段分隔符,默认为空格或制表符。与“-F”作用相同 |
---|---|
NF | 当前处理的行的字段个数 |
NR | 当前处理的行的行号(序数) |
$0 | 当前处理行的整行内容 |
$n | 当前处理行的第n个字段(第n列) |
FILENAME | 被处理的文件名 |
RS | 行分隔符。 awk从文件上读取资料时,将根据RS的定义把资料切割成许多条记录,而awk一次仅读入一条记录,以进行处理。预设值是‘\n’ |
$0 :在shell主代码中代表的是脚本本身;在函数体代表的是函数名;在awk命令中代表的是当前整行内容
one
two
three
four
FFF
five
six
seven
eigth
nine
ten
eleven
twelve
$n~"xxx" ~代表的是指定字段包含某个字符串
$n=="xxx" ~代表的是指定字段为某个字符串
$n!="xxx" ~代表的是指定字段不为某个字符串
BEGIN与END模式
awk 'BEGIN {操作1}; 条件 {操作2}; END {操作3}' 文件X
BEGIN {操作1} : awk 在读取文件之前执行的操作
条件 {操作2}: awk 逐行读取文件时执行的操作
END {操作3}: awk 在处理完文件所有行后执行的操作
例:
awk 'BEGIN {a=0}; /nologin$/ {a++;print a,$0}; END {print "共有"a"行"}' /etc/passwd
BEGIN {a=0} : 定义变量a=0
/nologin$/ {a++;print a,$0}: 执行以nologin结尾,且每执行一个a自加1,输出
END {print "共有"a"行"} : 输出以nologin结尾的行数
BEGIN模式表示,在处理指定的文本之前,需要先执行BEGIN模式中指定的动作,awk再处理指定的文本,之后再执行END模式中指定的动作,END{}语句块中,往往会放入打印结果等语句
通过管道符号、双引号调用shell命令
OFS
seq 10 | awk '{getline; print $0}'
getline 如果左右无 | 或 < ,是awk先读取文件首行内容,然后再由getline读取行内容并移动到下一行;
awk 'BEGIN {"hostname" | getline; print $0}'
getline 如果左右有 | 或 < ,getline用于直接获取内容,此时$0的值为getline获取内容
BEGIN模式(数组)
{a[$1]1+t}
awk根据指定字段读取每行的字段内容,使用字段内容作为数组的下标,如果出现相同内容的行,则用这个行内容做的数组的值自增1
END{for(i in a) {print a[ i],i}}
awk 读取完所有行内容后,使用for循环遍历这个数组的下标,打印每个下标出现的次数和下标的值