Ответ 1
Ничего больше, чем:
%hash = @array;
У меня есть массив и попытался преобразовать содержимое массива в хэш с ключами и значениями. Индекс 0 - это ключ, индекс 1 - это значение, индекс 2 - это ключ, индекс 3 - значение и т.д.
Но это не приводит к ожидаемому результату. Код ниже:
open (FILE, "message.xml") || die "Cannot open\n";
$var = <FILE>;
while ($var ne "")
{
chomp ($var);
@temp = split (/[\s\t]\s*/,$var);
push(@array,@temp);
$var = <FILE>;
}
$i = 0;
$num = @array;
while ($i < $num)
{
if (($array[$i] =~ /^\w+/i) || ($array[$i] =~ /\d+/))
{
# print "Matched\n";
# print "\t$array[$i]\n";
push (@new, $array[$i]);
}
$i ++;
}
print "@new\n";
use Tie::IxHash;
tie %hash, "Tie::IxHash";
%hash = map {split ' ', $_, 2} @new;
while ((my $k, my $v) = each %hash)
{
print "\t $k => $v\n";
}
Произведенный результат неверен:
name Protocol_discriminator attribute Mandatory type nibble value 7 min 0 max F name Security_header attribute Mandatory type nibble value 778 min 0X00 max 9940486857
name => Security_header
attribute => Mandatory
type => nibble
value => 778
min => 0X00
max => 9940486857
В выводе вы можете видеть, что хеш формируется только с одной частью, а другая часть массива не создается в хеше.
Может ли кто-нибудь помочь?
Ничего больше, чем:
%hash = @array;
В соответствующей заметке, чтобы преобразовать все элементы @array
в ключи %hash
. Некоторые люди, заканчивающиеся здесь, могут действительно захотеть этого вместо этого...
Это позволяет использовать существующую функцию:
my %hash;
$hash{$_}++ for (@array);