awk 使用
博客专区 > 昏鸦 的博客 > 博客详情
awk 使用
昏鸦 发表于4年前
awk 使用
  • 发表于 4年前
  • 阅读 202
  • 收藏 9
  • 点赞 0
  • 评论 0

腾讯云 技术升级10大核心产品年终让利>>>   

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}' 

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 "|" >> '+reultname

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

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

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

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

    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 

 


 

 

共有 人打赏支持
粉丝 7
博文 152
码字总数 57940
×
昏鸦
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: