24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1490  |  回复: 8
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

xiezhancnu

木虫 (小有名气)

[求助] perl程序求大神加以修改~~

现在有个文件夹TOTAL,该文件夹内有两个文件分别是a.txt和b.txt(见附件),我现在想生成这样的结果:
                  a.txt        b.txt(这一行可没有)
Os02t0249600-01        6236.420821        19861.20539
Os02t0242600-01                                      6550.062
Os03t0427300-01        7423.620595        26454.94742
Os01t0762500-00        5592.607026        31007.32272
第二行空格的意思是因为Os02t0242600-01在文件a.txt内没有对应的相,所以就空着!我现在写了一个程序,如下:
@gbk = glob('TOTAL/*');       
for($n=0;$n<=@gbk;$n++){
        open(input,"$gbk[$n]";       
        while(my $line={
     my @tmp=split("\t",$line);
     my $key = $tmp[0];  
     my $value = $tmp[4];  
     if (exists $hash{$key}){  
         $hash{$key} = $hash{$key}."\t".$value;  
     }else{
         $hash{$key} = $value;  
     }   
}
}       

delete $hash{GeneID};               
while(my($key,$value)=each %hash){
        print "$key\t$value\n";
}
生成的结果是这样的:
Os02t0249600-01        6236.420821        19861.20539
Os02t0242600-01        6550.062
Os03t0427300-01        7423.620595        26454.94742
Os01t0762500-00        5592.607026        31007.32272
也就是无法生成空格,第二行的6550.062应该在19861.20539这一列,请大神在我的 程序的基础上加以修改或者另写程序以实现我想要的结果,谢谢了~~~
回复此楼

» 本帖附件资源列表

  • 欢迎监督和反馈:小木虫仅提供交流平台,不对该内容负责。
    本内容由用户自主发布,如果其内容涉及到知识产权问题,其责任在于用户本人,如对版权有异议,请联系邮箱:xiaomuchong@tal.com
  • 附件 1 : a.txt
  • 2012-07-27 00:05:34, 740 bytes
  • 附件 2 : b.txt
  • 2012-07-27 00:05:48, 562 bytes

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiezhancnu

木虫 (小有名气)

引用回帖:
4楼: Originally posted by zhusheng303 at 2012-07-27 09:26:47
如果超过3个文件,解决方法如下,
@gbk = glob('TOTAL/*');
my $hash; ##### 构建一个hash变量     
for($n=0;$n<=@gbk;$n++){
        open(input,"$gbk";        
        while(my $line=< ...

跑不通啊,你试试!!
5楼2012-07-27 10:18:20
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 9 个回答

wizardfan

至尊木虫 (著名写手)

优秀版主

【答案】应助回帖

★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
xzhdty: 金币+1, 谢谢参与 2012-07-28 00:01:13
xiezhancnu: 金币+5 2012-08-11 09:35:09
use strict;
#use Data:umper;
opendir DIR, "total";
my @files = readdir DIR;
closedir DIR;
my %hash;
#store all data into a big hash
foreach my $file(@files){
        next unless ($file=~/\.txt$/);#only deal with text file
        &dealOneFile($file);
}
#print Dumper(%hash);

#find the union set of all keys from all files
my %key;
my @doneFiles = keys %hash;
@doneFiles = sort {$a cmp $b} @doneFiles;#sort the file namess
foreach my $tmp(@doneFiles){
        my %oneFile = %{$hash{$tmp}};
#        print Dumper(%oneFile);       
        foreach (keys %oneFile){
                $key{$_}++
        }
}
#print Dumper(%key);

#print header
$"="\t";
print "file\t@doneFiles\n";
#print content
foreach my $key(keys %key){
        print "$key";
        foreach my $file(@doneFiles){
                print "\t";
                print "$hash{$file}{$key}" if (exists $hash{$file}{$key});
        }
        print "\n";
}

sub dealOneFile{
        my $filename = "$_[0]";
        open IN,"total/$filename";
        ; #remove header
        while(my $line={
                chomp($line);
                my ($key,$a,$b,$c,$value) = split("\t",$line);
                $hash{$_[0]}{$key}=$value;
        }
}
2楼2012-07-27 03:12:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhusheng303

木虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
有以个问题要问你?
你在处理这个事,最终是不是只有这两文件?
如果是,解决办法如下,
while(my $line={
     my @tmp=split("\t",$line);
     my $key = $tmp[0];  
     my $value = $tmp[4];  
     if (exists $hash{$key}){  
         $hash{$key} = $hash{$key}."\t".$value;  
     }else{
         $hash{$key} = “". "\t" .$value;  ####或者写成 “$hash{$key} = “-". "\t" .$value”,用“-”表示缺失数据
     }
积极面对
3楼2012-07-27 08:58:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhusheng303

木虫 (小有名气)

【答案】应助回帖

如果超过3个文件,解决方法如下,
@gbk = glob('TOTAL/*');
my $hash; ##### 构建一个hash变量     
for($n=0;$n<=@gbk;$n++){
        open(input,"$gbk[$n]";        
        while(my $line={
                 my @tmp=split("\t",$line);
                 my $key = $tmp[0];  
                 my $value = $tmp[4];  
                 next if($key eq "GeneID";  #### 不记录“GeneID”这一行
                 $hash->{$key}{$n} = $value;  #### 每一个文件一个值
      }
}
my $fileNum=$#gbk;
foreach my $key (keys %{$hash}){
            print "$key";
            foreach my $i (0..$fileNum){
                       if(exists $hash->{$key}{$i}){
                                print "\t$$hash->{$key}{$i}";
                        }else{
                                print "\t";
                         }         
            }
            print "\n";

}
积极面对
4楼2012-07-27 09:26:47
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料与化工272求调剂 +12 阿斯蒂芬2004 2026-03-28 12/600 2026-03-29 16:16 by 学员8dgXkO
[考研] 340求调剂 +6 Amber00 2026-03-26 6/300 2026-03-29 12:06 by 无际的草原
[考研] 298求调剂 +3 种圣赐 2026-03-29 3/150 2026-03-29 12:06 by longlotian
[考研] 求调剂,一志愿 南京航空航天大学 ,080500材料科学与工程学硕,总分289分 +7 @taotao 2026-03-29 7/350 2026-03-29 12:03 by longlotian
[考研] 298求调剂 +4 种圣赐 2026-03-28 4/200 2026-03-29 08:42 by q1092522407
[考研] 321求调剂 +7 璞玉~~ 2026-03-25 8/400 2026-03-29 06:41 by 544594351
[考研] 一志愿哈尔滨工业大学材料与化工方向336分 +9 辰沐5211314 2026-03-26 9/450 2026-03-29 01:12 by 我是小康
[考研] 数一英一271专硕(085401)求调剂,可跨 +7 前行必有光 2026-03-28 8/400 2026-03-28 23:22 by 小木虫tim
[考研] 求调剂 +7 争取九点睡 2026-03-28 8/400 2026-03-28 21:07 by 争取九点睡
[考研] 320分,材料与化工专业,求调剂 +9 一定上岸aaa 2026-03-27 13/650 2026-03-28 15:00 by 神马都不懂
[考研] 一志愿厦门大学化学学硕307求调剂 +10 y7czhao 2026-03-26 10/500 2026-03-28 14:23 by 唐沐儿
[考研] 求化学调剂 +4 wulanna 2026-03-28 4/200 2026-03-28 13:37 by 唐沐儿
[考研] 材料与化工(0856)304求B区调剂 +8 邱gl 2026-03-27 8/400 2026-03-28 12:42 by 唐沐儿
[考研] 一志愿南京航空航天大学材料学硕求调剂 +3 @taotao 2026-03-28 3/150 2026-03-28 10:26 by JourneyLucky
[考研] 265求调剂 +8 小木虫085600 2026-03-27 8/400 2026-03-27 22:16 by 无际的草原
[考研] 一志愿 西北大学 总分282 英语一62 求调剂 +7 18419759900 2026-03-25 8/400 2026-03-27 16:38 by 18419759900
[考研] 274求调剂 +17 顾九笙要谦虚 2026-03-24 23/1150 2026-03-27 15:16 by caszguilin
[考研] 调剂 +3 李嘉图·S·路 2026-03-27 3/150 2026-03-27 11:19 by wangjy2002
[考研] 081200-11408-276学硕求调剂 +4 崔wj 2026-03-26 4/200 2026-03-27 08:04 by chemisry
[考研] 材料考研调剂生 +3 黄粱一梦千年 2026-03-24 3/150 2026-03-24 17:00 by barlinike
信息提示
请填处理意见