免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1575 | 回复: 8
打印 上一主题 下一主题

求助:关于对文本内进行分组并测算低于60分的数量. [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-15 16:52 |只看该作者 |倒序浏览
有这样格式的文本.
cj.txt
  1. a   95   wuli
  2. b   54   wuli
  3. c   84   huaxue
  4. d   44  huaxue
复制代码
我想用shell统计wuli,huaxue一共每科多少人并且找出其中多少人小于60.

最后得出的数字应该是

course   total   fail
wuli        2        1
huaxue   2        1

想用awk来做,想破头了...实在想不出.求救一下.或者指导我去看相关帖子..
置顶贴看过了...还是找不到头绪.

菜鸟求教.
十分感谢.

论坛徽章:
0
2 [报告]
发表于 2011-12-15 17:00 |只看该作者
你可以着重再看下awk数组这块
  1. awk '{c[$3]++}$2<60{a[$3]++}END{for (i in c) print i,"total:"c[i],"<60:"(i in a?a[i]:0)}' file
复制代码

论坛徽章:
0
3 [报告]
发表于 2011-12-15 17:07 |只看该作者
好的.感谢.

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
4 [报告]
发表于 2011-12-15 17:47 |只看该作者
有这样格式的文本.
cj.txt我想用shell统计wuli,huaxue一共每科多少人并且找出其中多少人小于60.

最后得 ...
lordroc 发表于 2011-12-15 16:52



    a   95   wuli

b   54   wuli

c   84   huaxue

d   44  huaxue
复制代码我想用shell统计wuli,huaxue一共每科多少人并且找出其中多少人小于60.

最后得出的数字应该是

course   total   fail
wuli        2        1
huaxue   2        1


course=;cat urfile | sort -k3 |  { echo course   total   fail;
while read A B C;do
    if [ "$C" != "$course" ];then
           if [ x"$course" != x ];then
                echo $course $total $fail
           fi
           course=$C
           total=1
           if [ $B -lt 60 ];then
               fail=1
           else
               fail=0
           fi
    else
          let total++
           if [ $B -lt 60 ];then
               let fail++
             fi
    fi
done;
}

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:51:162015年亚洲杯之阿曼
日期:2015-04-07 20:00:59
5 [报告]
发表于 2011-12-15 19:03 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
1
2015亚冠之吉达阿赫利
日期:2015-09-09 16:42:38
6 [报告]
发表于 2011-12-16 10:10 |只看该作者
awk '$2 < 60 {++b[$3]}{a[$3]="\t"++a[$3]"\t"b[$3]}END{for (i in a){print i a[i]}}'

论坛徽章:
0
7 [报告]
发表于 2011-12-16 12:14 |只看该作者
十分感谢大家.awk大部分都看明白了
shell脚本也看明白了~

再请教一下ywlscpl

i in a?a[i]:0这一句是啥意思..我没看明白.

论坛徽章:
0
8 [报告]
发表于 2011-12-16 13:28 |只看该作者
回复 7# lordroc
  1.     i in a?a[i]:0
  2. 是个三目运算表达式
  3. i in a条件满足?
  4. 满足:表达式值为a[i]
  5. 不满足:表达式值为0

  6. 因为存在本科目全部>60的情况
复制代码

论坛徽章:
0
9 [报告]
发表于 2011-12-16 14:09 |只看该作者
好的.感谢~
我考虑不周全.没有考虑到0的情况.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP