Я хотел бы поделиться с вами, ребята, функцией, которую я создал, чтобы увидеть, как я могу ее оптимизировать, или есть ли лучший способ сделать это.
sub flatten{
my($ref,$delim,$item_delim,$array,$str) = @_;
die("Required Hash Reference") unless isHash($ref);
$delim = $delim ? $delim :'_';
#dump into array hash vals #simplified
if(!$item_delim){
@{$array} = %{$ref};
}else{
my($keys,$values);
$keys = getKeys($ref);
$values = getValues($ref);
#item strings
if($#$keys > 0 && $#$values > 0){
#fix for issue where value[n] is empty
@{$array}= map{ (defined $$values[ $_ ]) ? $$keys[ $_ ].$item_delim.$$values[ $_ ] : $$keys[ $_ ].$item_delim } 0 .. int($#$keys);
}else{
log "No Values to flatten";
return '';
}
}
$str = join($delim,@{$array});
return $str;
}
Есть ли какие-то точки оптимизации, которые мне следуетбыть в курсе здесь?
В основном я хочу перейти от
$HASH => {
key1 => 'val1',
key2 => 'val2',
key3 => 'val3',
}
к $STRING= key1=val1&key2=val2 ...
ОБНОВЛЕНО
решение без модулей является предпочтительнымЯ действительно просто хочу знать, как эффективно сгладить хеш!
Обратите внимание, что некоторые функции здесь являются просто функциями-обертками, которые делают то, что они говорят.isHash getKeys ... не обращайте на них внимания!