awk 使用

0:处理一个文件的单次数量的和:cat t.txt | tr -s ' ' '\n' | sort | uniq -c | sort -r  | awk '{print $2 , $1}' 或者
tr -s ' ' '\n' < words.txt|sort|uniq -c|sort -nr|awk '{print $2, $1}' shell

1>awk '{x+=$2} END {print x}' 1.log  求1.log 中第二项全部数字的和数组

 2>cmd =' cat '+log1+' '+log2+' '+log3+' | awk \'$1 !~/^NULL/\'  | awk -F "|"  \'{a[$1]+=$2}END{for(x in a)print x"|"a[x]}\'  | sort -n  -r -k 2 -t "|" >> '+reultnamespa

计算 log中 第一列相等的,第二列和相加的, 而且按照第二列排序,排序

awk '{if ($2==200) a[$2]+=$2 }END{ for (b in a) print b,a[b]}' 1.logcmd

awk '{if ($2==200) a[$2]+=$2 }END{ for (b in a) print b,a[b]}' 1.logawk

3>awk '{ if($2 >10 && $2 < 100) print $0}' 1.log  查看第二列 大于10 小于100 的行file

4>cat t.log | grep ^$ | wc -l   计算一个文件的空行数grep

    cat t.* | grep ^$|wc -l  多个文件的空格行数
    cat  t.log | grep "^d.*g$" | wc -w   计算以 d开头以g结尾的单词的数量
    cat  t.log | grep "^[a-zA-Z].*g$" | wc -w 以字母开头,g结尾的单词的数量 程序

    cat  t.log | egrep "(df){2,}" | wc -l   df 连续出现至少两次以上的行数. (连续出现)数据

5>

现有2个文件:file1.txt和file2.txt,两个文件中均有两列数据,数据以tab分割。第一列为名字,第二列为数值。

现要求将file1某一名字的数值*10+file2中对应名字的数值*5输出到result.txt中,若是某一名字在某一文件中不存在则相应数值记为0。

 

举例:

输入:

file1内容:

aaax      1

bbb       2

cccd       3

file2内容:

bbb       2

cccd       6

dddx      4

 

输出:

aaax      10

bbb       30

cccd       60

dddx      20

 请使用shell命令(或者awk语句)实现以上程序

 cat a.txt | awk '{print $1, $2 * 10}' > c.txt

cat b.txt | awk '{print $1, $2 * 5}' > d.txt

 cat c.txt d.txt | sort |  awk '{if($1==prev) {count += $2}else {if (NR != 1)print prev, count; prev=$1; count=$2}} END {print  prev,count}'

a=(1 2 3 4 5)

  5 a[1]=100

  6 echo ${a[*]}

  7 echo ${a[1]}

  8 echo ${#a[*]}  数组的长度

  9 unset a[1] 删除

 10 unset a

 11 cat datafile.txt | while read myline

 12 do  

 13  echo "LINE:"$myline

 14  min = echo $myline | awk '{}'

 15 done 

相关文章
相关标签/搜索