亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 4086 | 回復(fù): 9
打印 上一主題 下一主題

兩列數(shù)據(jù)統(tǒng)計(jì)重復(fù)出現(xiàn)次數(shù) [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2015-04-23 14:14 |只看該作者 |倒序?yàn)g覽
-----------------data------------
A01     A
A01     C
A01     C
A01     C
A01     B
A01     A
A01     C
A02     D
A02     D
A02     B
A02     B
A02     A
A03     A
A03     D
A03     B
希望統(tǒng)計(jì)以第一列為范圍統(tǒng)計(jì)第二列出現(xiàn)的次數(shù),并且標(biāo)注出出現(xiàn)最多的第二列類別。希望得到的結(jié)果是
-----------------data------------
A01     A      2      C
A01     C      4      C
A01     C      4      C
A01     C      4      C
A01     B      1      C
A01     A      2      C
A01     C      4      C
A02     D      2      B,D
A02     D      2      B,D
A02     B      2      B,D
A02     B      2      B,D
A02     A      1      B,D
A03     A      1      A,B,D
A03     D      1      A,B,D
A03     B      1      A,B,D

論壇徽章:
26
2015亞冠之胡齊斯坦鋼鐵
日期:2015-06-25 21:40:202015亞冠之柏斯波利斯
日期:2015-08-31 17:03:192015亞冠之柏斯波利斯
日期:2015-11-07 13:10:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-11-10 06:20:00每日論壇發(fā)貼之星
日期:2015-11-10 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-11-26 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-12-02 06:20:00黃金圣斗士
日期:2015-12-07 17:57:4615-16賽季CBA聯(lián)賽之天津
日期:2015-12-23 18:34:14程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2016-01-02 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2016-01-06 06:20:00每日論壇發(fā)貼之星
日期:2016-01-06 06:20:00
2 [報(bào)告]
發(fā)表于 2015-04-23 16:00 |只看該作者

簡單場景直接利用字典就夠了。

求職 : 軟件工程師
論壇徽章:
3
程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-10-07 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-12-13 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2016-05-05 06:20:00
3 [報(bào)告]
發(fā)表于 2015-04-23 20:30 |只看該作者
用易表,foxtable 處理此類問題最合適了
candies_bio 該用戶已被刪除
4 [報(bào)告]
發(fā)表于 2015-04-23 23:58 |只看該作者
提示: 作者被禁止或刪除 內(nèi)容自動(dòng)屏蔽
candies_bio 該用戶已被刪除
5 [報(bào)告]
發(fā)表于 2015-04-24 00:05 |只看該作者
提示: 作者被禁止或刪除 內(nèi)容自動(dòng)屏蔽

論壇徽章:
7
戌狗
日期:2013-12-15 20:43:38技術(shù)圖書徽章
日期:2014-03-05 01:33:12技術(shù)圖書徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16賽季CBA聯(lián)賽之青島
日期:2016-03-17 20:36:13
6 [報(bào)告]
發(fā)表于 2015-04-24 03:44 |只看該作者
foxtable ~
  1. #!/usr/bin/perl

  2. my @foxtable;
  3. my $V = '\(^oo^)/';

  4. while (<DATA>) {
  5.     my ( $A, $B ) = split;
  6.     $V ne $A
  7.       ? push @foxtable, [ {}, $V = $A, $B ]
  8.       : push @{ $foxtable[-1] }, $B;
  9.     $foxtable[-1][0]{$B}++;
  10. }

  11. for (@foxtable) {
  12.     my ( $fox, $tab, @le ) = @$_;
  13.     my ($it) = sort { $b <=> $a } values %$fox;
  14.     my $that = join ',', sort grep $fox->{$_} == $it, keys %$fox;
  15.     print map join( "\t", $tab, $_, $fox->{$_}, $that ) . $/, @le;
  16. }

  17. __DATA__
  18. A01     A
  19. A01     C
  20. A01     C
  21. A01     C
  22. A01     B
  23. A01     A
  24. A01     C
  25. A02     D
  26. A02     D
  27. A02     B
  28. A02     B
  29. A02     A
  30. A03     A
  31. A03     D
  32. A03     B
復(fù)制代碼

論壇徽章:
1
羊年新春福章
日期:2015-04-28 20:40:58
7 [報(bào)告]
發(fā)表于 2015-04-28 20:38 |只看該作者

RE: 兩列數(shù)據(jù)統(tǒng)計(jì)重復(fù)出現(xiàn)次數(shù)

本帖最后由 清泉一邊 于 2015-04-28 20:43 編輯


為什么找不到寫代碼的<>了呢
   

論壇徽章:
1
羊年新春福章
日期:2015-04-28 20:40:58
8 [報(bào)告]
發(fā)表于 2015-04-28 20:42 |只看該作者
我覺得大神的這種寫法首先要確定按第一列排序,斗膽給大神的代碼加了一步排序
  1. #!/usr/bin/perl
  2. my @sort = map {$_->[0]}
  3.             sort {$a->[1] cmp $b->[1]}
  4.             map {[$_,split]}<DATA>;
  5. my @foxtable;
  6. my $V = 0;
  7. for my $sort (@sort) {
  8.     my ( $A, $B ) = split /\s+/,$sort;
  9.     if($V ne $A){
  10.     $V = $A;
  11.     push @foxtable, [ {}, $V, $B ];
  12.     }
  13.     else{
  14.       push @{ $foxtable[-1] }, $B;
  15. #      $foxtable[-1][0]{$B}++;
  16.     }
  17.     $foxtable[-1][0]{$B}++;
  18. }
  19. for (@foxtable) {
  20.     my ( $fox, $tab, @le ) = @$_;
  21.     my ($it) = sort { $b <=> $a } values %$fox;
  22.     my $that = join ',', sort grep $fox->{$_} == $it, keys %$fox;
  23.     print map join( "\t", $tab, $_, $fox->{$_}, $that ) . $/ ,sort @le;
  24. }

  25. __DATA__
  26. A01     A
  27. A01     C
  28. A01     C
  29. A01     C
  30. A01     B
  31. A01     A
  32. A01     C
  33. A02     D
  34. A02     D
  35. A02     B
  36. A02     B
  37. A02     A
  38. A03     A
  39. A03     D
  40. A03     B
復(fù)制代碼
回復(fù) 6# rubyish


   

論壇徽章:
7
戌狗
日期:2013-12-15 20:43:38技術(shù)圖書徽章
日期:2014-03-05 01:33:12技術(shù)圖書徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16賽季CBA聯(lián)賽之青島
日期:2016-03-17 20:36:13
9 [報(bào)告]
發(fā)表于 2015-04-29 22:25 |只看該作者
本帖最后由 rubyish 于 2015-04-29 18:31 編輯

回復(fù) 8# 清泉一邊

3Q~     

wo muce tade diyi lie shi youxude, suoyi...
ru yao gai?
wo xiang zhe keneng hui bijiao hao?
dan zhe yu yuqide jieguo bufu.
  1. my @sort = map { $_->[0] }
  2.   sort { $a->[1] cmp $b->[1] }
  3.   map { [ $_, split ] } <DATA>;
  4.   ...
  5. for my $sort (@sort) {
  6.     my ( $A, $B ) = split /\s+/, $sort;
復(fù)制代碼

  1. my @sort =
  2.   # map { $_->[0] }
  3.   sort { $a->[0] cmp $b->[0] }
  4.   map { [ split ] } <DATA>;
  5.   # map { [ $_, split ] } <DATA>;
  6.   # [ "A01     A", "A01", "A" ], $_ shi duoyude

  7. for my $sort (@sort) {
  8.     # my ( $A, $B ) = split /\s+/, $sort;
  9.     # BAD: 1 hang split 2 ci
  10.     my ( $A, $B ) = @$sort;
復(fù)制代碼
zhe shi lingyige xiefa(wuxude):
yiyang shiyong foxtable ~
  1. #!/usr/bin/perl
  2. my %foxtable;

  3. while (<DATA>) {
  4.     my ( $A, $B ) = split;
  5.     $foxtable{$A}{$B}++;
  6. }

  7. for my $k ( sort keys %foxtable ) {
  8.     my %F   = %{ $foxtable{$k} };
  9.     my ($V) = sort { $b <=> $a } values %F;
  10.     my $T   = join ',', sort grep $F{$_} == $V, keys %F;
  11.     print map { "$k\t$_\t$F{$_}\t$T\n" x $F{$_} } sort keys %F;
  12. }

  13. __DATA__
  14. A01     A
  15. A01     C
  16. A01     C
  17. A02     A
  18. A03     A
  19. A03     D
  20. A01     C
  21. A01     B
  22. A01     A
  23. A01     C
  24. A02     D
  25. A02     D
  26. A02     B
  27. A02     B
  28. A03     B
復(fù)制代碼

論壇徽章:
307
程序設(shè)計(jì)版塊每周發(fā)帖之星
日期:2016-04-08 00:41:33操作系統(tǒng)版塊每日發(fā)帖之星
日期:2015-09-02 06:20:00每日論壇發(fā)貼之星
日期:2015-09-02 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-09-04 06:20:00每日論壇發(fā)貼之星
日期:2015-09-04 06:20:00每周論壇發(fā)貼之星
日期:2015-09-06 22:22:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-09-09 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-09-19 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-09-20 06:20:00每日論壇發(fā)貼之星
日期:2015-09-20 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-09-22 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2015-09-24 06:20:00
10 [報(bào)告]
發(fā)表于 2016-09-21 22:39 |只看該作者
  1. #!/usr/bin/perl
  2. use strict;
  3. use warnings;

  4. my ($id, @aData, %hCnt) = "";
  5. map {my ($k, $v) = split; $id ne $k ? push (@aData, [$k, [$v]]) : push (@{$aData[-1][-1]}, $v); $id = $k} <DATA>;
  6. foreach my $ra (@aData){
  7.     $hCnt{$_}++ for @{$ra->[-1]};
  8.     my @aT = map {[$_, $hCnt{$_}]} sort {$hCnt{$b} <=> $hCnt{$a}} keys %hCnt;
  9.     my @aChars = $aT[0][0];
  10.     foreach (1 .. $#aT){
  11.         push (@aChars, $aT[$_][0]) if ($aT[0][-1] == $aT[$_][-1]);
  12.     }
  13.     print join ("\t", $ra->[0], $_, $hCnt{$_}, join (",", sort @aChars)), "\n" for @{$ra->[-1]};
  14.     %hCnt = ();
  15. }

  16. __DATA__
  17. A01     A
  18. A01     C
  19. A01     C
  20. A01     C
  21. A01     B
  22. A01     A
  23. A01     C
  24. A02     D
  25. A02     D
  26. A02     B
  27. A02     B
  28. A02     A
  29. A03     A
  30. A03     D
  31. A03     B
復(fù)制代碼
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP