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 

相關文章
相關標籤/搜索