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