Beefy Boxes and Bandwidth Generously Provided by pair Networks
Your skill will accomplish
what the force of many cannot

Re: Sort an array which contains date formatted elements

by cdarke (Prior)
on Jul 17, 2007 at 13:26 UTC ( #627019=note: print w/replies, xml ) Need Help??

in reply to Sort an array which contains date formatted elements

Alternatively use a custom sort. It is a little more complicated than normal because of the date format. For example:
use strict; my @files = qw (webadmin_jul_10_2007.log webadmin_jul_11_2007.log webadmin_jul_12_2007.log webadmin_jul_13_2007.log webadmin_jul_14_2007.log webadmin_jul_7_2007.log webadmin_jul_8_2007.log webadmin_jul_9_2007.log); sub bydate { # Extract non-numeric and date # Assumes text after date is the same my ($afront, $aday, $ayear) = $a =~ /^([[:alpha:]_]+)(\d+)_(\d+)/; my ($bfront, $bday, $byear) = $b =~ /^([[:alpha:]_]+)(\d+)_(\d+)/; my $retn = ($afront cmp $bfront); $retn = ($ayear <=> $byear) if $retn == 0; $retn = ($aday <=> $bday) if $retn == 0; return $retn } my @sorted = sort bydate @files; local $" = "\n"; print "@sorted\n";

Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://627019]
[erix]: hm zipfile-SQLite sounds useful, have you tried it already, Corion?

How do I use this? | Other CB clients
Other Users?
Others scrutinizing the Monastery: (7)
As of 2018-01-24 08:50 GMT
Find Nodes?
    Voting Booth?
    How did you see in the new year?

    Results (256 votes). Check out past polls.