免费注册 查看新帖 |

Chinaunix

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

[数值计算] 請教依據條件作統計 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-05-15 21:59 |只看该作者 |倒序浏览
本帖最后由 xmi 于 2013-05-15 22:29 编辑

請教各位我想把以下的作個統計, 想得出2 個不同結果:
15May13-04:45:19:164 A/1   (3) apple at APP05 a1
15May13-06:45:23:846 A/1   (3) apple at APP02 a2
15May13-08:07:54:535 A/1   (3) apple at APP02 a2
15May13-09:19:43:138 A/1   (3) apple at APP02 a2
15May13-10:25:53:856 A/1   (3) apple at APP03 a12
15May13-10:27:43:971 A/1   (3) apple at APP02 a3
15May13-02:37:57:981 A/1   (3) apple at APP04 a4
15May13-02:37:58:895 A/1   (3) orange at OOP12 a1
15May13-02:38:09:756 A/1   (3) orange at OOP08 a3
15May13-02:38:16:095 A/1   (3) orange at OOP11 a11
15May13-02:41:27:961 A/1   (3) orange at OOP10 a34
15May13-02:42:52:505 A/1   (3) orange at OOP12 a2
15May13-04:21:48:867 A/1   (3) pear at PEA12 a23
15May13-06:07:41:565 A/1   (3) pear at PEA12 a24



結果如附件...

謝謝!

result.jpg (58.18 KB, 下载次数: 78)

result

result

论坛徽章:
13
丑牛
日期:2013-08-16 15:08:22技术图书徽章
日期:2013-11-26 10:13:40双鱼座
日期:2013-11-08 15:03:26戌狗
日期:2013-11-08 13:52:30技术图书徽章
日期:2013-11-05 14:06:30戌狗
日期:2013-10-31 11:45:42CU十二周年纪念徽章
日期:2013-10-24 15:41:34天秤座
日期:2013-10-11 14:55:08子鼠
日期:2013-09-26 19:36:35水瓶座
日期:2013-09-26 17:44:56午马
日期:2013-08-26 10:24:23丑牛
日期:2013-08-19 14:43:22
2 [报告]
发表于 2013-05-15 23:35 |只看该作者
先回答着,明天再继续修改
结果一:
  1. awk '{a[$4" "$6]++}END{for(i in a)print i,a[i]}' test | sort -nk +1 | awk '{if(!a[$1]++){split($0,b);print b[1]}}1'   
  2. apple
  3. apple APP02 4
  4. apple APP03 1
  5. apple APP04 1
  6. apple APP05 1
  7. orange
  8. orange OOP08 1
  9. orange OOP10 1
  10. orange OOP11 1
  11. orange OOP12 2
  12. pear
  13. pear PEA12 2
复制代码
结果2:
  1. awk '{a[$4" "$6" "$7]++}END{for(i in a)print i,a[i]}' test | sort -nk +1 | awk '{if(!a[$1]++){split($0,b);print b[1]}}1'
  2. apple
  3. apple APP02 a2 3
  4. apple APP02 a3 1
  5. apple APP03 a12 1
  6. apple APP04 a4 1
  7. apple APP05 a1 1
  8. orange
  9. orange OOP08 a3 1
  10. orange OOP10 a34 1
  11. orange OOP11 a11 1
  12. orange OOP12 a1 1
  13. orange OOP12 a2 1
  14. pear
  15. pear PEA12 a23 1
  16. pear PEA12 a24 1
复制代码

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
3 [报告]
发表于 2013-05-16 09:30 |只看该作者
本帖最后由 yestreenstars 于 2013-05-16 09:31 编辑
  1. [root@localhost ~]# cat i
  2. 15May13-04:45:19:164 A/1   (3) apple at APP05 a1
  3. 15May13-06:45:23:846 A/1   (3) apple at APP02 a2
  4. 15May13-08:07:54:535 A/1   (3) apple at APP02 a2
  5. 15May13-09:19:43:138 A/1   (3) apple at APP02 a2
  6. 15May13-10:25:53:856 A/1   (3) apple at APP03 a12
  7. 15May13-10:27:43:971 A/1   (3) apple at APP02 a3
  8. 15May13-02:37:57:981 A/1   (3) apple at APP04 a4
  9. 15May13-02:37:58:895 A/1   (3) orange at OOP12 a1
  10. 15May13-02:38:09:756 A/1   (3) orange at OOP08 a3
  11. 15May13-02:38:16:095 A/1   (3) orange at OOP11 a11
  12. 15May13-02:41:27:961 A/1   (3) orange at OOP10 a34
  13. 15May13-02:42:52:505 A/1   (3) orange at OOP12 a2
  14. 15May13-04:21:48:867 A/1   (3) pear at PEA12 a23
  15. 15May13-06:07:41:565 A/1   (3) pear at PEA12 a24
  16. [root@localhost ~]# awk '{a[$4];b[$6];c[$4,$6]++}END{for(i=1;i<=asorti(a,d);i++){print d[i];for(j in b)if(c[d[i],j])print d[i],j,c[d[i],j]}}' i
  17. apple
  18. apple APP02 4
  19. apple APP03 1
  20. apple APP04 1
  21. apple APP05 1
  22. orange
  23. orange OOP08 1
  24. orange OOP10 1
  25. orange OOP11 1
  26. orange OOP12 2
  27. pear
  28. pear PEA12 2
  29. [root@localhost ~]# awk '{a[$4];b[$6];c[$7];d[$4,$6,$7]++}END{for(i=1;i<=asorti(a,e);i++){print e[i];for(j in b)for(k in c)if(d[e[i],j,k])print e[i],j,k,d[e[i],j,k]}}' i
  30. apple
  31. apple APP02 a2 3
  32. apple APP02 a3 1
  33. apple APP03 a12 1
  34. apple APP04 a4 1
  35. apple APP05 a1 1
  36. orange
  37. orange OOP08 a3 1
  38. orange OOP10 a34 1
  39. orange OOP11 a11 1
  40. orange OOP12 a1 1
  41. orange OOP12 a2 1
  42. pear
  43. pear PEA12 a23 1
  44. pear PEA12 a24 1
  45. [root@localhost ~]#
复制代码

论坛徽章:
0
4 [报告]
发表于 2013-05-16 09:37 |只看该作者
本帖最后由 心若寒江雪 于 2013-05-16 09:39 编辑

[root@test1 opt]# awk '{b[$4"\t"$6]++}END{for(i in b){printf "%s\t %s\n",i,b}}' file
orange  OOP12    2
apple   APP02    4
apple   APP03    1
apple   APP04    1
orange  OOP08    1
apple   APP05    1
pear    PEA12    2
orange  OOP10    1
orange  OOP11    1
[root@test1 opt]# awk '{b[$4"\t"$6"\t"$7]++}END{for(i in b){printf "%s\t %s\n",i,b}}' file
orange  OOP08   a3       1
orange  OOP12   a1       1
apple   APP05   a1       1
orange  OOP12   a2       1
apple   APP04   a4       1
apple   APP03   a12      1
orange  OOP11   a11      1
pear    PEA12   a23      1
apple   APP02   a2       3
pear    PEA12   a24      1
apple   APP02   a3       1
orange  OOP10   a34      1

论坛徽章:
0
5 [报告]
发表于 2013-05-16 18:57 |只看该作者
厉害。{:3_200:}学习了。

论坛徽章:
0
6 [报告]
发表于 2013-05-16 21:39 |只看该作者
本帖最后由 xmi 于 2013-05-16 21:43 编辑

回复 2# 代号:军刀


   很利害呀, 真的萬謝意!!衷心感激烈!  想不到會做到... 請教可否解說一下? 請問可把結果的每一欄也弄齊整嗎?
   你說再修改... 可如何再修改呢?

论坛徽章:
0
7 [报告]
发表于 2013-05-16 21:40 |只看该作者
本帖最后由 xmi 于 2013-05-16 21:44 编辑

回复 3# yestreenstars


    很利害呀, 真的萬謝意!!衷心感激!  我試試看...請問可把結果的每一欄也弄齊整嗎?

论坛徽章:
0
8 [报告]
发表于 2013-05-16 21:43 |只看该作者
回复 4# 心若寒江雪


    很利害呀, 真的萬謝意!!衷心感激! ..學習學習.... 請問可把結果的每一欄也弄齊嗎?

论坛徽章:
0
9 [报告]
发表于 2013-05-16 23:12 |只看该作者
现在就是对齐的,只是贴出来不是了
回复 8# xmi


   

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
10 [报告]
发表于 2013-05-17 09:02 |只看该作者
改一下分隔符就好了:
  1. [root@localhost ~]# awk -vOFS='\t' '{a[$4];b[$6];c[$4,$6]++}END{for(i=1;i<=asorti(a,d);i++){print d[i];for(j in b)if(c[d[i],j])print d[i],j,c[d[i],j]}}' i
  2. apple
  3. apple   APP02   4
  4. apple   APP03   1
  5. apple   APP04   1
  6. apple   APP05   1
  7. orange
  8. orange  OOP08   1
  9. orange  OOP10   1
  10. orange  OOP11   1
  11. orange  OOP12   2
  12. pear
  13. pear    PEA12   2
  14. [root@localhost ~]# awk -vOFS='\t' '{a[$4];b[$6];c[$7];d[$4,$6,$7]++}END{for(i=1;i<=asorti(a,e);i++){print e[i];for(j in b)for(k in c)if(d[e[i],j,k])print e[i],j,k,d[e[i],j,k]}}' i
  15. apple
  16. apple   APP02   a2      3
  17. apple   APP02   a3      1
  18. apple   APP03   a12     1
  19. apple   APP04   a4      1
  20. apple   APP05   a1      1
  21. orange
  22. orange  OOP08   a3      1
  23. orange  OOP10   a34     1
  24. orange  OOP11   a11     1
  25. orange  OOP12   a1      1
  26. orange  OOP12   a2      1
  27. pear
  28. pear    PEA12   a23     1
  29. pear    PEA12   a24     1
  30. [root@localhost ~]#
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP