您的位置:首页 > 运维架构 > Linux

Linux命令之awk学习笔记

2015-01-31 12:06 417 查看
一、
awk命令:
root@www ~]# awk '条件类型 1{动作 1} 条件类型 2{动作 2} ...' filename

二、
awk 后面接两个单引号并加上大括号 {} 来设定想要对数据进行的处理动作
在每一行的每个字段都是有变量名称的,那就是 $1, $2... 等变量名称。
$0 代表『一整列资料』的意思~如图:









以上面的例子来说,第一行的 $0 代表的就是『root .... 』那一行啊! 由此可知,刚刚上面五行当中,整个awk 的处理流程是:
1. 读入第一行,并将第一行的资料填入 $0, $1, $2.... 等变数当中;
2. 依据 "条件类型" 的限制,判断是否需要进行后面的 "动作";
3. 做完所有的动作与条件类型;
4. 若还有后续的『行』的数据,则重复上面 1~3 的步骤,直到所有的数据都读完为止。

经过这样的步骤,你会晓得, awk 是『以行为一次处理的单位』, 而『以字段为最小的处理单位』

三、
好了,那么 awk 怎么知道我到底这个数据有几行?有几栏呢?这就需要 awk 的内建变量的帮忙啦~
变量名称 代表意义

NF 每一行 ($0) 拥有的字段总数(Numberof Field,当前记录的field个数)
NR 目前 awk 所处理的是『第几行』数据(Thenumber of input records)
FS 目前的分隔字符,默认是空格键(Field separator,输入字段分隔符),即要处理的那一行的$1、$2 、$3……的分割字符是什么。

我们读入第一行的时候,那些变数 $1,$2... 默人还是以空格键为分隔的,所以虽然我们定义了 FS=":" 了, 但是即仅能在第二行后才开始生效。那么怎么办呢?我们可以预先设定 awk 的变量啊!使用BEGING关键词:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: