免费注册 查看新帖 |

Chinaunix

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

怎么统计某列行数? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-01-20 16:41 |只看该作者 |倒序浏览
我有如下文件,格式如下:
AMD Athlon(tm) 64 X2 Dual Core Processor 5000+,NVIDIA GeForce 9500 GT @ 494.48798
AMD Athlon(tm) 64 X2 Dual Core Processor 5000+,NVIDIA GeForce 9500 GT @ 494.48798
Intel(R) Pentium(R) Dual  CPU  E2160  @ 1.80GHz,NVIDIA GeForce 9500 GT @ 494.48798
Intel(R) Pentium(R) Dual  CPU  E2160  @ 1.80GHz,NVIDIA GeForce 9500 GT @ 494.48798
AMD Athlon(tm) 64 X2 Dual Core Processor 5000+,NVIDIA GeForce 9500 GT @ 494.48798
AMD Athlon(tm) 64 X2 Dual Core Processor 5000+,NVIDIA GeForce 9500 GT @ 494.48798

我怎么统计以逗号分隔的共有相同的第一列共有多少行和相同的第二列列共有多少行?
比如上面的结果应为:
cpu类型
AMD Athlon(tm) 64 X2 Dual Core Processor 5000+:4
NVIDIA GeForce 9500 GT @ 494.48798:6
Intel(R) Pentium(R) Dual  CPU  E2160  @ 1.80GHz:2

[ 本帖最后由 ora_admin 于 2009-1-20 16:45 编辑 ]

论坛徽章:
9
2015亚冠之阿尔纳斯尔
日期:2015-09-10 16:21:162015亚冠之塔什干火车头
日期:2015-07-01 16:23:022015年亚洲杯之巴勒斯坦
日期:2015-04-20 17:19:46子鼠
日期:2014-11-13 09:51:26未羊
日期:2014-08-28 18:13:36技术图书徽章
日期:2014-02-21 09:30:15酉鸡
日期:2014-01-14 11:12:49天蝎座
日期:2013-12-09 17:56:53平安夜徽章
日期:2015-12-26 00:06:30
2 [报告]
发表于 2009-01-20 16:44 |只看该作者
原帖由 ora_admin 于 2009-1-20 16:41 发表
我有如下文件,格式如下:
AMD Athlon(tm) 64 X2 Dual Core Processor 5000+,NVIDIA GeForce 9500 GT @ 494.48798
AMD Athlon(tm) 64 X2 Dual Core Processor 5000+,NVIDIA GeForce 9500 GT @ 494.48798

AMD Athlon(tm) 64 X2 Dual Core Processor 5000+,NVIDIA GeForce 9500 GT @ 494.48798

我怎么统计以逗号分隔的第二列和第三列共有多少行?


不好意思,我怎么没看到以逗号分隔的第三列?

论坛徽章:
0
3 [报告]
发表于 2009-01-20 17:17 |只看该作者
  1. awk -F "," '{a[$1]++;b[$2]++}END{for (i in a) print i":"a[i];for (j in b) print j":"b[j]}' file
复制代码

论坛徽章:
0
4 [报告]
发表于 2009-01-20 18:35 |只看该作者
如果要统计所有行(包含只出现过一次的行),就用
awk -F "," '{a[$1]++;b[$2]++}END{for (i in a) print i":"a[i];for (j in b) print j":"b[j]}' file
如果要统计包含重复的列有多少行,就用
awk -F "," '{a[$1]++;b[$2]++}END{for (i in a)if(a[i]>1)print i":"a[i];for (j in b)if(b[i]>1)print j":"b[j]}' file

论坛徽章:
0
5 [报告]
发表于 2009-01-20 21:41 |只看该作者
活学活用
awk -F "," '{++S[$1];++S[$2]} END {for(a in S) print a, S[a]}' urfile

论坛徽章:
0
6 [报告]
发表于 2009-01-21 00:53 |只看该作者
原帖由 moartel 于 2009-1-20 21:41 发表
活学活用
awk -F "," '{++S[$1];++S[$2]} END {for(a in S) print a, S[a]}' urfile


如果$1==$2,就不行了

论坛徽章:
1
2015年亚洲杯之韩国
日期:2015-04-24 09:07:02
7 [报告]
发表于 2009-01-21 09:14 |只看该作者
awk -F ',' '{a[$1]++;b[$2]++} END {for(i in a){print i,a} for(j in b) {print j,b[j]}}'

论坛徽章:
0
8 [报告]
发表于 2009-01-21 09:20 |只看该作者
原帖由 cooljean2008 于 2009-1-21 00:53 发表


如果$1==$2,就不行了


[root@ns ~]# awk -F "," '{++S[$1];++S[$2]} END {for(a in S) print a, S[a]}' 1
NVIDIA GeForce 9500 GT @ 494.48798 8
Intel(R) Pentium(R) Dual  CPU  E2160  @ 1.80GHz 2
AMD Athlon(tm) 64 X2 Dual Core Processor 5000+ 4
[root@ns ~]# cat 1
AMD Athlon(tm) 64 X2 Dual Core Processor 5000+,NVIDIA GeForce 9500 GT @ 494.48798
AMD Athlon(tm) 64 X2 Dual Core Processor 5000+,NVIDIA GeForce 9500 GT @ 494.48798
Intel(R) Pentium(R) Dual  CPU  E2160  @ 1.80GHz,NVIDIA GeForce 9500 GT @ 494.48798
Intel(R) Pentium(R) Dual  CPU  E2160  @ 1.80GHz,NVIDIA GeForce 9500 GT @ 494.48798
AMD Athlon(tm) 64 X2 Dual Core Processor 5000+,NVIDIA GeForce 9500 GT @ 494.48798
AMD Athlon(tm) 64 X2 Dual Core Processor 5000+,NVIDIA GeForce 9500 GT @ 494.48798
NVIDIA GeForce 9500 GT @ 494.48798,NVIDIA GeForce 9500 GT @ 494.48798
[root@ns ~]#

论坛徽章:
0
9 [报告]
发表于 2009-01-21 09:37 |只看该作者
原帖由 moartel 于 2009-1-21 09:20 发表


[root@ns ~]# awk -F "," '{++S[$1];++S[$2]} END {for(a in S) print a, S[a]}' 1
NVIDIA GeForce 9500 GT @ 494.48798 8
Intel(R) Pentium(R) Dual  CPU  E2160  @ 1.80GHz 2
AMD Athlon(tm) 64 X2 Du ...


那请问,第一列NVIDIA GeForce 9500 GT 重复几次,第二列NVIDIA GeForce 9500 GT 又重复几次

论坛徽章:
0
10 [报告]
发表于 2009-01-21 09:54 |只看该作者
[quote]原帖由 [i]cooljean2008[/i] 于 2009-1-21 09:37 发表 [url=http://bbs.chinaunix.net/redirect.php?goto=findpost&pid=9976427&ptid=1357547][img]http://bbs.chinaunix.net/images/common/back.gif[/img][/url]


那请问,第一列NVIDIA GeForce 9500 GT 重复几次,第二列NVIDIA GeForce 9500 GT 又重复几次 [/quote]

明白了
awk -F "," '{++S[$1];++N[$2]} END {for (a in S) print a, S[a];for(b in N) print b, N[b] }' urfile

[[i] 本帖最后由 moartel 于 2009-1-21 09:56 编辑 [/i]]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP