in reply to Re^5: Sorting based on any column
in thread Sorting based on any column
Its giving error "Use of uninitialized value in numeric comparison (<=>)"
That's because this is almost certainly not doing whatever you think it's doing:
$ab = "\$a";
That's taking the value of $a and appending it to a backslash and making it the value of $ab, so "11" becomes "\11". I'm guessing that you're trying to make $ab a reference to $a, but to do that you'd need to leave out the quotes, and that would also change the later code.
Personally, if I wanted to have a toggle between two different ways to sort, I'd do it like this (unless the sort comparison is very complex, in which case it should be in a separate subroutine anyway):
sub sort_array_by_column_asc_or_desc { my( $array, $column, $order ) = @_; if( $order eq 'desc' ){ return sort { put_descending_sort_comparison_here } @$array; } else { # default to ascending sort return sort { put_ascending_sort_comparison_here } @$array; } }
Note: the else there isn't necessary, but I like it because it makes the choice obvious.
Aaron B.
Available for small or large Perl jobs and *nix system administration; see my home node.
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^7: Sorting based on any column
by AnomalousMonk (Archbishop) on May 21, 2015 at 15:08 UTC | |
by aaron_baugher (Curate) on May 21, 2015 at 21:46 UTC |