Re: [問題] for迴圈問題

看板Perl作者 (Neisseria)時間9年前 (2014/08/22 14:40), 5年前編輯推噓3(300)
留言3則, 3人參與, 最新討論串2/2 (看更多)
※ 引述《par4322 (Queeny)》之銘言: : if(-e $arrfile){ : @fileheader=`awk '{print \$1}' $arrfile`; : @Parr=`awk '{print \$2}' $arrfile`; 這裡也可以不用 awk,像我自己就看不懂 awk 程式碼 另外,fileheader 和 parr 似乎是連帶一起的 可以考慮做成一個 list of list my @filelists; my $arrfile = 'arrfile'; open my $FH, "<", $arrfile or die "$!\n"; while (<$FH>) { chomp; my @a = split /\s+/; push @filelists, \@a; } close $FH or die "$!\n"; : for($j=0;$j<@fileheader;$j++){ : chomp($fileheader[$j]); : chomp($Parr[$j]); : $file=$fileheader[$j]=grep'A' $arrfile |`awk '{print $0}' $arrfile`; : &auto($file,$Parr[$j]); 這裡可能誤會 grep 的用法,查一下 perldoc -f grep 可看到 grep BLOCK LIST grep 接收一個 list,然後將所有條件為真的元素傳回為一個 list 所以不是用 scalar 去接,這樣會變成 list 的數目 如果已經用迴圈了,就不需要用 grep foreach my $e (@filelists) { my $s = substr $e->[0], 13, 1; if ($s eq 'A') { auto($e->[0], $e->[1]); } } 如果用 grep,可能的寫法如下 my @list_a = grep { substr($_->[0], 13, 1) eq 'A' } @filelists foreach my $e (@list_a) { auto($e->[0], $e->[1]); } 只是在這裡,跟直接用迴圈比起來,沒省下多少程式碼 : $file1=$fileheader[$j]=grep'B' $arrfile |`awk '{print $0}' $arrfile`; : $file2=$fileheader[$j]=grep'C' $arrfile |`awk '{print $0}' $arrfile`; : &autoH($file1,$file2,$Parr[$j]); : .......... : } 這裡的問題最大 看起來是要兩層迴圈 但無法確定你 autoH 第三個引數要跟著 file1 還是 file2 假設第三個引數要跟著 file1,可能的寫法如下 foreach my $e1 (@filelists) { my $s1 = substr $e1->[0], 13, 1; if ($s1 eq 'B') { foreach my $e2 (@filelists) { my $s2 = substr $e1->[0], 13, 1; if ($2 eq 'C') { autoH($e1->[0], $e2->[0], $e1->[1]); } } } } 但是這裡可能還要想一下,確定結果是不是真的如同預期 有可能需要重寫過 autoH 也不一定 : sub auto {......... : sub autoH {........... ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 59.105.57.132 ※ 文章網址: http://www.ptt.cc/bbs/Perl/M.1408689610.A.3FF.html

08/22 16:28, , 1F
推認真解答(Y)
08/22 16:28, 1F

08/24 09:55, , 2F
推認真
08/24 09:55, 2F

08/24 19:38, , 3F
大推認真 感謝~(y)
08/24 19:38, 3F
※ 編輯: Neisseria (60.251.46.166), 12/24/2018 16:23:43
文章代碼(AID): #1JzkNAF_ (Perl)
文章代碼(AID): #1JzkNAF_ (Perl)