それぞれが値として 2 つの配列を含む 2 つの HoA があります。次のコードは、最初の HoA をそのキーでソートし、キーが同じ場合は、最初の配列の対応する値でソートします。
#!/usr/bin/perl
use warnings;
use strict;
use Data::Dumper;
$Data::Dumper::Sortkeys = 1;
my @array1 = qw (1 1 1 4 5); # Note '1' appears several times
my @array2 = qw (10 45 2 1 6);
my @array3 = qw (a b c d e);
my %hash1;
push @{$hash1{$array1[$_]}}, [ $array2[$_], $array3[$_] ] for 0 .. $#array1;
my @arrayA = qw (2 5 1 0 4);
my @arrayB = qw (1 3 6 0 7);
my @arrayC = qw (a z v i d);
my %hash2;
push @{$hash2{$arrayA[$_]}}, [ $arrayB[$_], $arrayC[$_]] for 0 .. $#arrayA;
for my $key (sort keys %hash1) {
for my $value (sort { $a->[0] <=> $b->[0] } @{ $hash1{$key} } ) {
my ($arr2, $arr3) = @$value;
print "$key: $arr2\t$arr3\n";
}
}
上記の関数を実行できるようにしたいのですが、さらに (@array3 と @arrayC など) の間で値を比較したいと考えています。値が両方の配列に存在する場合は、それをスキップして、各行のキーと値を出力したい 'unique ' その配列に。
hash1 と hash2 の出力 (現状のまま)。値の重複は で示され*
ます。
ハッシュ1
1: 2 c
1: 10 a *
1: 45 b
4: 1 d *
5: 6 e
ハッシュ2
0: 0 i
1: 6 v
2: 1 a *
4: 7 d *
5: 3 z
望ましい出力: (array3 と arrayC の一致する要素を含む行を削除)
0: 0 i
1: 2 c
1: 6 v
1: 45 b
5: 3 z
5: 6 e
すなわち削除:
1: 10 a
4: 1 d
最初のハッシュから、そして:
2: 1 a
4: 7 d
二番目から
キーを比較する場合は、次を使用します。
for my $key (sort keys %hash1) {
if (exists $hash1{$key}) {
next;
}
}
2 つの配列を比較する場合は、次のように使用します。
foreach (@array3) {
if ($_~~ @arrayC) {
next;
}
}
HoA の値に対して同じことを達成するにはどうすればよいですか?