2

次のようにグループ化した番号が空白行で区切られたテキストファイルがあります。

42.034 41.630 40.158 26.823 26.366 25.289 23.949

34.712 35.133 35.185 35.577 28.463 28.412 30.831

33.490 33.839 32.059 32.072 33.425 33.349 34.709

12.596 13.332 12.810 13.329 13.329 13.569 11.418

注:グループは常に同じ長さであり、グループが大きい場合、たとえば500の数字の長さの場合は、複数の行の長さに配置できます。グループを配列に入れて、ファイルの長さに沿って反復することを考えていました。

私の最初の質問は、配列2の最初の要素を配列1から、配列3を配列2から、2番目の要素についても同様に、グループの最後までどのように減算する必要があるかということです。

すなわち:

34.712-42.034,35.133-41.630,35.185-40.158 ...till the end of each group

33.490-34.712,33.839-35.133   ..................

次に、1つのグループの最初の要素の違いを最後まで保存します(2番目の質問:どのように?)

すなわち:

34.712-42.034 ; 33.490-34.712 ; and so on in one group

35.133-41.630 ; 33.839-35.133 ; ........

私は初心者なので、どんな提案も役に立ちます。

4

2 に答える 2

6

ファイルを開いていると仮定すると、以下は簡単なスケッチです

use List::MoreUtils qw<pairwise>;
...

my @list1 = split ' ', <$file_handle>;
my @list2 = split ' ', <$file_handle>;

my @diff  = pairwise { $a - $b } @list1, @list2;

pairwise最も簡単な方法です。

それ以外の場合は、古いスタンバイがあります。

# construct a list using each index in @list1 ( 0..$#list1 )
# consisting of the difference at each slot.
my @diff = map { $list1[$_] - $list2[$_] } 0..$#list1;
于 2011-03-01T15:24:46.420 に答える
0

Axeman のコードを機能させるための残りのインフラストラクチャは次のとおりです。

#!/usr/bin/perl
use strict;
use warnings;
use List::MoreUtils qw<pairwise>;

my (@prev_line, @this_line, @diff);
while (<>) {
    next if /^\s+$/; # skip leading blank lines, if any
    @prev_line = split;
    last;
}

# get the rest of the lines, calculating and printing the difference,
# then saving this line's values in the previous line's values for the next
# set of differences
while (<>) {
    next if /^\s+$/; # skip embedded blank lines

    @this_line = split;
    @diff      = pairwise { $a - $b } @this_line, @prev_line;

    print join(" ; ", @diff), "\n\n";

    @prev_line = @this_line;
}

したがって、次の入力が与えられます。

1 1 1

3 2 1

2 2 2

あなたは得るでしょう:

2 ; 1 ; 0

-1 ; 0 ; 1
于 2011-04-06T01:52:29.957 に答える