AWK
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 (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|