免费注册 查看新帖 |

Chinaunix

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

如何对39列数据按列求和 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-08 21:34 |只看该作者 |倒序浏览
问题描述:

现有一个文件(12067行),每一行都是39列,每一列的数都是0或者1,各列之间tab键分开。(示例文件给出了部分数据)。


问题处理:

我想对每一列累加求和,最后输出和值。


我的想法:

设置39个数组@arr1...@ar39, 然后逐行读入数据依次赋给39个数组,最后对每一个数组求和。

感觉想法有点stupid, 而且我不知道怎样一下子定义39个数组,一个个写太麻烦了吧~,而且这样是不是很占内存呀~

希望大家提供给我一些解决思路和办法.

data.rar

259 Bytes, 下载次数: 36

data.rar

259 Bytes, 下载次数: 38

论坛徽章:
0
2 [报告]
发表于 2011-12-08 21:46 |只看该作者
你直接用  excel 求和不行吗?

论坛徽章:
0
3 [报告]
发表于 2011-12-08 22:11 |只看该作者
  1. #!/usr/bin/perl -w
  2. use 5.010;

  3. my @res;
  4. while (<>) {
  5.    next if /^\s*$/;
  6.    my @line = split;
  7.    for (0 .. $#line) {
  8.       $res[$_] += $line[$_];
  9.    }
  10. }

  11. for (0 .. $#res) {
  12.    say $_+1, ": $res[$_]";
  13. }
复制代码

论坛徽章:
1
未羊
日期:2014-09-08 22:47:27
4 [报告]
发表于 2011-12-09 14:12 |只看该作者
本帖最后由 wxlfh 于 2011-12-09 14:15 编辑
  1. open my $fh, "<", "your_file";
  2. my @data;
  3. while my $line (<$fh>) {
  4.     my @lines = split /\t/, $line;
  5.     $data[$_] += $lines[$_] for 0..$#lines;
  6. }
  7. close $fh;
  8. print "@data";
复制代码

论坛徽章:
0
5 [报告]
发表于 2011-12-09 15:12 |只看该作者
回复 2# cobrawgl


谢谢提醒,这个我曾经也想过~
不过我的问题有一步可能没太描述清楚,其实不是对全部,只是某些行(具体那些行由算法控制,所以我没有说)~~
同时一并谢谢3楼,4楼的帮忙~

论坛徽章:
1
未羊
日期:2014-09-08 22:47:27
6 [报告]
发表于 2011-12-09 21:53 |只看该作者
回复 5# lijie_perl
  1. open my $fh, "<", "your_file";
  2. my @data;
  3. my $flag = sub {};  #判断函数
  4. while my $line (<$fh>) {
  5.     next if $flag->($line);  #如果不需要统计
  6.     my @lines = split /\t/, $line;
  7.     $data[$_] += $lines[$_] for 0..$#lines;
  8. }
  9. close $fh;
  10. print "@data";
复制代码

论坛徽章:
0
7 [报告]
发表于 2015-01-13 20:31 |只看该作者
请问 $flag=sub {}是怎么来判断哪些是需要求和统计的?
谢谢回复 4# wxlfh


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP