1、格式:awk -F ‘分隔符’ ‘command’
打印多个段,但是显示以空格分隔
awk -F ‘:’‘{print $3,$4}’ filename
指定输出分隔
‘{print $3“:”$4}’or‘OFS=”#” {print $3,$4}’
显示含字符串的行及行号
awk-F ‘:’‘/root/’ ‘{print NR”:”$3}’ //NR指行号
显示行数段数
‘{printNR”:”NF}’
显示最后一段
‘{print$NF}’
2、查询判断
AWK支持特殊字符 + ? | () *
新符号~(表匹配),逻辑符号||\>\<\==\<=\>==\&&\!=
【匹配】(print之前)
/root|ftp/
‘$1~/root/ {print $3}’
‘$1~/root/ || $3>500 {print NR’:’$0}’ //$0表示全部文件
$1==/root/ //精确完全匹配
NR>20 && $3<500
$7!=”/sbin/nologin”
‘OFS=”:”,$7=$3+$5 {print $0}’
‘if ($1==”root”) {print $0}’
【实例】计算列和
# awk -F ‘:’ ‘{(sum=sum+$3)}; END {print sum}’
# sum =0; for i in `awk -F”:” {print $3}`; do sum=$[$sum+$i]; done; echo $su
【awk使用扩展】
1、awk简介
awk命令是shell提供的工具,可以参与shell程序设计,是一种自解释的程序设计语言。
awk能从一个或多个文本文件或字符串中逐个记录或扫描;将每个记录与匹配模式相比较;当发现匹配格式时,抽取数据或格式化报文,或执行相应的文本操作,并不改变输入文本文件的内容。
awk借鉴了C语言结构,包含有:
条件与循环执行语句
数值变量与字符串变量
正则表达式
pringf语句
格式:awk [-F(字段分隔符)] [参数赋值] [‘匹配串’] [-f awk脚本文件] [输入文件]
-F不定义默认分隔符是空格或制表符;
匹配串如果不定义,则默认为所有行。
输入文件为要处理的文件序列,如果未指定则awk接受键盘输入,并将结果显示到屏幕上。
2、基本使用
(1)规则:
一个记录是一行,以换行符结束。记录由字段构成,空格、制表符是默认的字段分隔符;
如果一个记录中有NF个字段,可分别用$1~$NF访问这些字段,特殊值$0表示整行。如:
awk ‘$0 ~/abc/’ file //显示文件中含abc的所有行
awk -F: ‘{print $1}’ /etc/passwd //显示系统的用户
awk ‘$2==”develops”{print} ’ dfba.dat
awk ‘$3>10 {print}’ afba.dat
(2)awk模式
模式分为关系表达式、逻辑表达式、正则表达式和BEGIN-END。表达式使用时需用小括号括起。
操作符:! && || != > < >= <= ~ !~
例:
awk -F: ‘$2 == “”’ /etc/passwd //查看没有密码的用户
awk -F: ‘{if($3>=500) print $0}’ /etc/passwd
[正则表达式]
匹配含有字符串的行 ~/string/
匹配含有数字的行 ~/[0-9].*/
匹配含有大写字母的行 ~/[A-Z].*/
匹配含有小写字母的行 ~/[a-z].*/
匹配只有一个字符的行 ~/^.$/
匹配不含数字的行 !~/[0-9].*/
匹配不含大写字母的行 !~/[A-Z].*/
匹配不含小写字母的行 !~/[a-z].*/
例:awk -F: ‘$1 /zhjg/’ /etc/passwd
(3)预定义变量表
属性 说明
$0 当前记录(作为单个变量)
$1~$n 当前记录的第n个字段,字段间由FS分隔
FS 输入字段分隔符 默认是空格
NF 当前记录中的字段个数,就是有多少列
NR 已经读出的记录数,就是行号,从1开始
RS 输入的记录他隔符默 认为换行符
OFS 输出字段分隔符 默认也是空格
ORS 输出的记录分隔符,默认为换行符
ARGC 命令行参数个数
ARGV 命令行参数数组
FILENAME 当前输入文件的名字
IGNORECASE 如果为真,则进行忽略大小写的匹配
ARGIND 当前被处理文件的ARGV标志符
CONVFMT 数字转换格式 %.6g
ENVIRON UNIX环境变量
ERRNO UNIX系统错误消息
FIELDWIDTHS 输入字段宽度的空白分隔字符串
FNR 当前记录数
OFMT 数字的输出格式 %.6g
RSTART 被匹配函数匹配的字符串首
RLENGTH 被匹配函数匹配的字符串长度
SUBSEP 数组分隔符。将(I,J)转换为 I SUBSEP J,模拟多维数组用
例:awk ‘{print NF,NR,FS $0} END {print FILENAME}’ personalpc.txt
(4)awk操作
字符串运算
关系运算:< > <= >= == != >> ~ !~
逻辑运算:! && ||
赋值操作符:= += -= *= /= %= ^ ++ --
数值运算
+ - * / %
函数运算
内部函数表
Cos() 求余弦
sin() 求正弦
exp() 对表达式取自然指数
log() 求表达式的自然对数
int() 取表达式的整数部分,向0截取
length() 求字符串长度
index(string1,string2) 字符串2在字符串1中的位置;不在则返回0
split(string,a,c) 以字符c为分隔符将s分割成a[1]~a[n]并返回n
sprint(格式,……) 格式化
sub(string,M) 用$0中最左边最长字串代替M
substr(string,M) 求起始于位置M的字符串的子串
gsub(string,M) 在整个$0中用M替代字符串
match(M,N) 测试M是否包含匹配N的字符串
awk ‘gsub(/tel486/,/tel586) {print $0}’ personalpc.txt
awk ‘BEGIN {print split(“1111#2222#3333#4444”,abcdarray,”#”)}’
awk ‘BEGIN {print match(“ABCDXYZ”,/X/)}’ //返回匹配字符在所找字符串中的首字符的位置
awk ‘length($0)>20 {print NR}’ personalpc.txt