解释:-v OFS=","这个是设置输出时的列分割符,$1 in a这个是b.txt文件中的第一列的值是不是在数组a的key中,这个对做程序的来说很好理解,各种语言当中都有这样的用法,或者函数。例如,php中有in_array函数。比较一下,方法1和方法2中的print,方法1我加了双引号,方法2我却没有加,但是输出的效果却是一样的。 二、去除重复的值 复制代码 代码如下: [root@krlcgcms01 mytest]# cat repea //文件repea a b c d e f b d b a f e 1 2 2 1
如果有a,b和b,a这样的情况,就删除b,a,当然数字也一样; 实现方法1: 复制代码 代码如下: awk "{for(i=1;i<=NF;i++)a[i]=$i;asort(a);for(i=1;i<=length(a);i++)printf a[i]" ";printf "
"}" repea|sort|uniq 1 2 a b b d c d e f
解释:for(i=1;i<=NF;i++)a[i]=$i;将每一列中的二个字段放到数组中,asort(a),这个数组进行排序,后面的代码是将数组数据输出来,通sort命令对输入的数据进行排序,相同数据会排在一起,通过uniq来进行去除相同的列。这种方法比较有通用性,不光适合二列,三列,四列都行。不过效率差了点。 实现方法2: 复制代码 代码如下: [root@krlcgcms01 mytest]# awk "{a[$0]=$0;if (!($2 OFS $1 in a)) print a[$0] }" repea a b c d e f b d 1 2 [root@krlcgcms01 mytest]# awk "{a[$0];if (!($2 OFS $1 in a)) print }" repea a b c d e f b d 1 2
解释:方法2的二种写法,出来的结果是一样的,a[$0];没有赋值也没有报错,为什么呢?awk在遇到这样没有定义的变量时,会给它一个初值。if (!($2 OFS $1 in a))表示返转字段不在数组a中,这里所说的在,表示key是不是存在,不是值。print 不写默认是一行。 实现方法3: 复制代码 代码如下: [root@krlcgcms01 mytest]# awk "!a[$1_$2]++&&!a[$2_$1]++" repea a b c d e f b d 1 2 [root@krlcgcms01 mytest]# awk "{if(!a[$1_$2]++&&!a[$2_$1]++)print $0;}" repea a b c d e f b d 1 2
把都是数字的行,最大的那个数字加起来,第一行是2,第二行是3,每四行是3,第五行是4,总和是12 复制代码 代码如下: function max(one,two){ if(one > two){ sum = sum + one; }else{ sum = sum + two; } } {if($1~"[0-9]" && $2~"[0-9]") max($1,$2);} END{print "sum="sum}
在max方法里面,变量sum是会影响外面的,这里的sum是全局的。 [root@krlcgcms01 mytest]# awk -f add.sh sum sum=12 复制代码 代码如下: function max(one,two,sum){ //方法中的sum局部变量 if(one > two){ sum = sum + one; }else{ sum = sum + two; } } {if($1~"[0-9]" && $2~"[0-9]") max($1,$2,sum);} END{print "sum="sum} //所以为空
[root@krlcgcms01 mytest]# awk -f add.sh sum sum= 复制代码 代码如下: function max(one,two,sum){ if(one > two){ sum = sum + one; }else{ sum = sum + two; } return sum //加上return就可以了 } {if($1~"[0-9]" && $2~"[0-9]") sum = max($1,$2,sum);} END{print "sum="sum}