in reply to Re^2: Compare Arrays, Return Values
in thread Compare Arrays, Return Values

OK. Well, first use: (a) use strict; (b) use warnings; (c) my variables.

Now, in your input loop you have:

@t = split(/\t/, $_) ; $t[4]= $AB{[4]} ;
which is a horrible mess :-( What you want to do is:
$AB{$alpha_numeric_field} = $numeric_field ;
where the two fields are elements of @t, I cannot tell which.

The output process contains:

if ($var1[2] and exists $Ab{$var1[2]}) { print OUT "$var1[0]\t$var1[1]\t$var1[2]\t$AB[4]\n" ; }
which looks as though it would be OK, but for $AB[4], which ought to be $AB{$var1[2]}. (Oh. And it should be $AB{...} in the if !).

use strict would have picked up the $Ab{} mistake (undefined hash %Ab) and the use of $AB[4] (undefined array @AB). It would not, however, have picked up $AB{[4]}, which is the kind of honest-to-goodness inscrutability that Perl is justly famous for, and which one grows to be deeply fond of.

BTW, rather than:

@var1 = split(/\t/,$_) ;
you can write (for example):
($field_name, $other_field, $further_field, ...) = split(...) ;
then you have each field in a variable with a meaningfull name -- more friendly than $var1[2] etc.

Replies are listed 'Best First'.
Re^4: Compare Arrays, Return Values
by de2425 (Sexton) on Aug 28, 2008 at 17:25 UTC
    Thank you so very much!!! This worked like a charm. I cannot tell you how greatful I am. I knew it had to be something simple that my brain wasn't registering for some reason. Thank you again.