awk脚本
$0,意即所有域。 有两种方式保存shell提示符下awk脚本的输出。最简单的方式是使用输出重定向符号>文件名,下面的例子重定向输出到文件wow。
#awk '{print $0}' grade.txt > wow 第二种方法是使用tee命令,在输出到文件的同时输出到屏幕。
#awk '{print $0}' grade.txt | tee delete_me_and_die 打印field-1和field-4,
#awk '{print $1,$4}' grade.txt 打印信息头放置在BEGIN模式部分
#awk 'BEGIN {print "Name Belt\n----------------------"}{print $1"\t"$4}' grade.txt
END语句在所有文本处理动作执行完之后才被执行。
#awk 'BEGIN {print "Name Belt\n----------------------"}{print $1"\t"$4} END{"end-of-report"}' grade.txt 为使一域号匹配正则表达式,使用符号‘~’后紧跟正则表达式 如果只要打印brown腰带级别可知其所在域为field-4
可以写出表达式{if($4~/brown/) print $0}意即如果field-4包含brown,打印它。 匹配记录找到时,如果不特别声明,awk缺省打印整条记录。 if语句简写
#awk '$0 ~ /Brown/' grade.txt 匹配包含48的记录
#awk '$3~/48/ {print $0}' grade.txt 只匹配等于48,
#awk '$3=="48" {print $0}' grade.txt 不匹配符号是!~ 小于
awk '{if($6 < $7) print $1}' grade.txt 设置大小写可使用[]符号
查询文件中级别为green的所有记录,不论其大小写,
awk '/[Gg]reen/' grade.txt 第一域的第四个字符是a,使用句点.
#awk '$1 ~ /^...a/' grade.txt 或关系匹配
#awk '$0 ~ /(Yellow|Brown)/' grade.txt 复合表达式即为模式间通过使用下述各表达式互相结合起来的表达式:
&& AND : 语句两边必须同时匹配为真。
|| OR:语句两边同时或其中一边匹配为真。
! 非求逆
#awk '{if($1=="P.bunny" && $4=="Yellow") print $0}' grade.txt
#awk '{if($1=="P.bunny" || $4=="Yellow") print $0}' grade.txt awk内置变量
ARGC 命令行参数个数
ARGV 命令行参数排列
ENVIRON 支持队列中系统环境变量的使用
FILENAME awk浏览的文件名
FNR 浏览文件的记录数
FS 设置输入域分隔符,等价于命令行-F选项
NF 浏览记录的域个数
NR 已读的记录数
OFS 输出域分隔
ORS 输出记录分隔符
RS 控制记录分隔符 快速查看记录个数,应使用NR
#awk 'END {print NR}' grade.txt 使用NF变量显示每一条读记录中有多少个域,并在END部分打印输入文件名。
#awk '{print NF,NR,$0} END{print FILENAME}' grade.txt 检查文件中是否有记录。下面的例子只有在文件中至少有一个记录时才查询Brown级别记录。使用AND复合语句实现这一功能。
$awk '{if(NR>0 && $4~/Brown/) print $0}' grade.txt NF的一个强大功能是将变量$PWD的返回值传入awk并显示其目录。这里需要指定域分隔符/。
#pwd
/usr/local/etc
#echo $PWD | awk -F/ '{print $NF}'
etc 另一个例子是显示文件名
$echo "/usr/local/etc/rc.sybase" | awk -F/ '{print $NF}'
rs.sybase
awk脚本的更多相关文章
- awk 脚本同时解析多个文件
ARGC The number of command line arguments (does not include options to gawk ...
- 一些我后写出来的awk脚本
mail.awk function mailByShell(receiver, sender, subject, content, __ARGVEND__, xhead, xfrom, xmime, ...
- AWK 脚本编写习惯
教训总结: 不能忽略了脚本语言的编写规范! 创建数组的时候初始化,特别是在for循环中使用的数组: u_count[; g_count[; 认真对待对象,特别是数组的命名: username_to_d ...
- 一次awk脚本的重构
# 脚本功能说明: # . 检查URL中的域名是否是指定版本的域名 # . 对访问bid,authorid的游客身份排重,并累加其pv # 全局变量说明 # DOMIAN_LIST 是数组,key是要 ...
- awk脚本使用的几种方法
1. awk名包含在文件内 [root@nhserver1 08]# cat sample.txtaaabbbccc [root@nhserver1 08]# cat readsample.awkaw ...
- 【sed / awk脚本编写】
awk awk分为BEGIN部分,正则匹配部分,END部分三部分. 我一般在BEGIN部分定义一些变量,正则部分用于匹配和执行一些解析和统计,END部分用于输出结果. 总体结构: awk 'BEGIN ...
- 听说awk语言也可以编写脚本
导读 从 awk 系列开始,我们都是在命令行或者脚本文件里写一些简短的 awk 命令和程序.然而 awk 和 shell 一样也是一个解释型语言.通过从开始到现在的一系列的学习,你现在能写可以执行的 ...
- Linux Shell脚本入门--awk命令详解
简单使用: awk :对于文件中一行行的独处来执行操作 . awk -F :'{print $1,$4}' :使用‘:’来分割这一行,把这一行的第一第四个域打印出来 . 详细介绍: AWK命令介绍 ...
- shell脚本 awk工具
awk工具概述awk编程语言/数据处理引擎基于模式匹配检查输入文本,逐行处理并输出通常在shell脚本中,或取指定的数据单独用时,可对文本数据做统计 命令格式格式一:awk [选项] '[条件]{编辑 ...
随机推荐
- iOS学习36数据处理之SQLite数据库
1. 数据库管理系统 1> SQL语言概述 SQL: SQL是Structured Query Language(结构化查询语言)的缩写.SQL是专为数据库而建立的操作命令集, 是一种功能齐全的 ...
- BZOJ3868 : The only survival
枚举每个点到$1$的距离,若$>k$则视为$k+1$,那么$d_1=1,d_n=k$. 对于$i$,如果$1\leq d_i\leq k$,则一定要存在一条边长度为$d_i-d_j$,且其他边长 ...
- UVa 11388 & 丝帛
一直在想丝帛题要不要贴呢...后来觉得还是贴了吧...反正没人看...blog是开给自己看的...偶尔无聊打打blog也显得生活非常充实... 题意: 给一个gcd和lcm求满足啊他们的最小的a和b. ...
- AFNetworking 2.0 出现Use of undeclared identifier AFURLSessionManager错误
当向下面使用时会出现错误 #import "AFNetworking.h" #import "AFURLSessionManager.h" AFURLSessi ...
- ACM: HDU 5285 wyh2000 and pupil-二分图判定
HDU 5285 wyh2000 and pupil Time Limit:1500MS Memory Limit:65536KB 64bit IO Format:%I64d &a ...
- ACM: HDU 1869 六度分离-Dijkstra算法
HDU 1869六度分离 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Descri ...
- [总结]HNOI2015省队选拔
// 此博文为迁移而来,写于2015年4月21日,不代表本人现在的观点与看法.原始地址:http://blog.sina.com.cn/s/blog_6022c4720102vy9t.html 这次省 ...
- 【POJ】3678 Katu Puzzle
http://poj.org/problem?id=3678 题意:很幼稚的题目直接看英文题面= = #include <cstdio> #include <cstring> ...
- SQLSERVER的NULL
判断数据库中某个值是否为null(而不是'null',空字符串'',若干个空格' ') 一定不能用=null 或 !=null,而要用is null 或 is not null. 在sqlserver ...
- qt编译常见错误
一.fatal error: QWidget: 没有那个文件或目录 类似于找不到文件目录的,在.pro文件中添加 QT +=\ widgets 类似就可以编译通过