perl posix :: strptime-私のデータは午前9時31分のように見えます - 分を抽出して計算を実行したい
質問
コンマ区切りファイルの2番目の列に存在する指定された時間から分を抽出し、計算を実行したいと思います。時間の形式は次のとおりです。
9:31:00 AM
微小値を抽出し、これまでの1日の合計分を計算したいと思います。私はこれをサブルーチンget_timeで行います。しかし、返された値は常にゼロであるため、Posix :: Strptimeを正しく使用していないと思います。どんな洞察も素晴らしいでしょう。ありがとうございました。
#!/usr/bin/env perl
use strict;
use POSIX::strptime;
use Text::CSV;
sub get_time
{
my($str) = @_;
my ($sec, $min, $hour) = (POSIX::strptime($str, '%I:%M:%S')) [3,4,5];
print "$hour\n";
return($hour*60 + $min)
}
open my $fh, "<", datafile.txt
my $csv = Text::CSV->new() or die "Failed to create Text::CSV object";
my $line = <$fh>;
die "Failed to parse line <<$line>>\n\n" unless $csv->parse($line);
my @columns = $csv->fields();
while ($line = <$fh>)
{
chomp $line;
die "Failed to parse line <<$line>>\n\n" unless $csv->parse($line);
my @columns = $csv->fields();
die "Insufficient columns in <<$line>>\n" if scalar(@columns) < 1;
my $minute = get_time($columns[1]);
print "$minute\n";
}
解決
get_timeには、ラインがあります
my ($sec, $min, $hour) = (POSIX::strptime($str, '%I:%M:%S')) [3,4,5];`
による ドキュメント, 、Strptime Returns
($sec, $min, $hour, $mday, $mon, $year, $wday, $yday) = POSIX::strptime("string", "Format");
だからあなたは必要だと思われます
my ($sec, $min, $hour) = (POSIX::strptime($str, '%I:%M:%S')) [0,1,2];
代わりは。
幸運を!
他のヒント
タイムゾーンと場合によっては日付を知らずに、特定の時間の前の1日の1分間で1分の数を正しく決定することは不可能です。
$ perl -MDateTime -E'
for (10..16) {
my $dt = DateTime->new(
year => 2011,
month => 3,
day => $_,
hour => 9,
minute => 31,
second => 0,
time_zone => "America/New_York",
);
( my $ref_dt = $dt->clone )->truncate(to => "day");
my $minutes = ($dt - $ref_dt)->in_units("minutes");
say($dt->ymd, " ", $minutes);
}
'
2011-03-10 571
2011-03-11 571
2011-03-12 571
2011-03-13 511 <------
2011-03-14 571
2011-03-15 571
2011-03-16 571
所属していません StackOverflow