W perlu zawsze istnieje więcej niż jeden sposób na zrobienie czegoś. Oto ten, który wykorzystuje tylko moduł, który jest standardowo wyposażony w Perlu:
#! perl -w
use strict;
use Time::Local;
my $d1 = "Feb 3 12:03:20";
my $d2 = "Feb 4 00:00:30";
# Your date formats don't include the year, so
# figure out some kind of default.
use constant Year => 2012;
# Convert your date strings to Unix/perl style time in seconds
# The main problems you have here are:
# * parsing the date formats
# * converting the month string to a number from 1 to 11
sub convert
{
my $dstring = shift;
my %m = ('Jan' => 0, 'Feb' => 1, 'Mar' => 2, 'Apr' => 3,
'May' => 4, 'Jun' => 5, 'Jul' => 6, 'Aug' => 7,
'Sep' => 8, 'Oct' => 9, 'Nov' => 10, 'Dec' => 11);
if ($dstring =~ /(\S+)\s+(\d+)\s+(\d{2}):(\d{2}):(\d{2})/)
{
my ($month, $day, $h, $m, $s) = ($1, $2, $3, $4, $5);
my $mnumber = $m{$month}; # production code should handle errors here
timelocal($s, $m, $h, $day, $mnumber, Year - 1900);
}
else
{
die "Format not recognized: ", $dstring, "\n";
}
}
my $t1 = convert($d1);
my $t2 = convert($d2);
print "Diff (seconds) = ", $t2 - $t1, "\n";
Aby zrobić to naprawdę produkcja gotowe, potrzebuje lepszej obsługi od roku (na przykład, co się stanie, gdy data rozpoczęcia jest w grudniu i na końcu data w styczniu?) i lepszą obsługę błędów (na przykład, co się stanie, jeśli zostanie skasowany skrót 3-znakowy miesiąca?).
wow ... bardziej zaangażowany niż się spodziewałem ... dzięki –
@xivix, jest niepotrzebnie skomplikowany do tego, co chcesz. [Odpowiedź vmpstr] (http://stackoverflow.com/a/9134822/132382) jest całkowicie wykonalny tutaj. – pilcrow
Wszystko zależy od tego, ile modułów możesz użyć. Zobacz odpowiedź @vmpstr, używając Date :: Parse. Jeśli instalacja tego modułu jest akceptowalna, przejdź do niego. Prawdopodobnie wykona lepszą pracę z obsługą różnych formatów danych i możliwych błędów niż ten krótki fragment kodu. – theglauber