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