awk太牛了,博大精深,学不透,学了不用,又忘。
所以花了一天,自己总结了基础,以后就当字典查(容易忘)。有不对的地方,忘大家指出。
[ganzl@cmdb ~]$ more /etc/passwd root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbin/nologin
概念:
(字段,记录,就是行跟列的意思啦,我自己取的):
字段:上面/etc/passwd内有7个字段。以":"分割,$1就是root。$0,$n:当前记录,当前记录的第N个字段
记录:有两行记录
这4个概念比较重要:
NF:字段数量
NR:记录行数
$NF:当前行最后一个字段的内容
$NR:当前记录的第NR个内容
例子:
awk '{FS=":"}NR==7||NF==8{print NF,$NF,NR,$NR}' /etc/passwd awk -F: 'NR==2||NF==8{print NF,$NF,NR,$NR}' /etc/passwd
FS:字段分割符号,默认是空格
RS:记录分割符号,默认是空格
例子:
#!/bin/sh exec <host.list i=1 while read line do if [ $i -eq 4 ];then echo -n "`echo $line|awk '{print $1}'`">>tmp.host else echo -n "`echo $line|awk '{print $1}'`,">>tmp.host fi ((i++)) done df df df df dddddddddddddddddddddddddddddddd
awk 'BEGIN{FS=" ";RS=""}{print $1,$2,$3}' 3.txt #不在同一行--(变成)-->同一行,同时空白记录--(变成)-->""
ORS:记录输出分隔符
OFS:字段输出分隔符
例子:
awk 'BEGIN{FS=" ";RS="";OFS="###";ORS="???"}{print $1,$2,$3}' 3.txt
运算符
赋值运算符:
= += -= *= /= %= ^= **= 赋值语句
逻辑运算符:
||逻辑或 &&逻辑与
正则运算符:
~ !~ 匹配正则表达式和不关系运算符
关系运算符:< <= > >= != ==
算术运符:
+ - 加,减
* / & 乘,除与求余
+ - ! 一元加,减和逻辑非
^ *** 求幂
++ -- 增加或减少,作为前缀
三目运算符:?
例子: awk 'BEGIN{a=5;a+=4;print a}' awk 'BEGIN{a=1;b=2;print(a>2||b<9)}' echo|awk 'BEGIN{a="aaa1000dbbb"}a~/abc/{print "ok"}' awk 'BEGIN{a=11;if(a>9){print "ok"}}' awk 'BEGIN{a=1;print a++,++a}' awk 'BEGIN{a="b";print a=="c"?"yes":"no"}'
awk的正则:
^ :行首定位符 /^root/ 匹配所有以 root 开头的行
$ :行尾定位符 /root$/ 匹配所有以 root 结尾的行
. :匹配任意单个字符 /r..t/
* :匹配 0个或多前导字符 (包括回车 ) /a*ool/ /a*ool/ 匹配0个或多a之后紧跟着ool的行,比如 ool ,aaaaool aaaaool 等
+ :匹配 1个或多前导字符 /a+b/ 匹配 1个或多个 a加 b的行,比如ab,aab 等
? :匹配 0个或 1个前导字符 /a?b/ 匹配 b或 ab 的行
[] :匹配指定字符组内的任意一个字符 /^[abc] 匹配以字母 a或 b或 c开头的行 开头的行
[^] :匹配不在指定字符组内任意一个字符 /^[^abc]/ 匹配不以字母 a或 b或 c开头的行
() :子表达式组合 /(rool)+/ 表示一个或多rool组合,当有一些 组合,当有一些 字符需要组合时,使用括号起来
| :或者的意思 /(root)|B/ 匹配 root 或者 B的行
:转义字符 /a /// 匹配 a//
~,!~: 匹配,不匹配的条 件语句 $1~/root/ 匹配第一个字段包含符root的所有 记
x{m} :x重复 m次 /(root){3}/ 注意这个括号
x{m,} :x重复至少 m次 /(root){3,}/
X{m,n} :x重复至少 m次,但不超过 n次
例子: awk '/tcpdump/{print $0,NR}' /etc/passwd ifconfig eth2|awk -F'[" ":]+' 'NR==2{print $4,$6}'|awk '{print $1}' awk -F: '$1=="root"{print $0}' /etc/passwd netstat -nal| awk '/^tcp/{s[$NF]++}END{for(i in s)print i,s[i]}' 统计web服务器访问IP: awk '{count[$1]++}END{for (ip in count){print ip,count[ip]}}' /var/log/httpd/access_log