在perl中,给定自纪元以来的微秒数,如何以如下格式转换为localtime
my $time = sprintf "%02ld,%02ld,%02ld.%06ld", $hour, $min, $sec, $usec;
例如:“输入= 1555329743301750 (从纪元开始的微秒)输出= 070223.301750”
发布于 2019-05-31 05:10:30
核心Time::Piece可以进行转换,但它不处理亚秒级,因此您需要自己处理这些转换。
use strict;
use warnings;
use Time::Piece;
my $input = '1555329743301750';
my ($sec, $usec) = $input =~ m/^([0-9]*)([0-9]{6})$/;
my $time = localtime($sec);
print $time->strftime('%H%M%S') . ".$usec\n";
Time::Moment提供了一个更好的选项来处理亚秒,但是需要一些帮助来查找系统本地时间中任意时间的协调时差,我们可以使用Time::Moment::Role::TimeZone。
use strict;
use warnings;
use Time::Moment;
use Role::Tiny ();
my $input = '1555329743301750';
my $sec = $input / 1000000;
my $class = Role::Tiny->create_class_with_roles('Time::Moment', 'Time::Moment::Role::TimeZone');
my $time = $class->from_epoch($sec, precision => 6)->with_system_offset_same_instant;
print $time->strftime('%H%M%S%6f'), "\n";
最后,DateTime稍微重一点,但可以自然地处理所有事情,至少可以达到微秒级的精度。
use strict;
use warnings;
use DateTime;
my $input = '1555329743301750';
my $sec = $input / 1000000;
my $time = DateTime->from_epoch(epoch => $sec, time_zone => 'local');
print $time->strftime('%H%M%S.%6N'), "\n";
(为了避免可能出现的浮点问题,您可以用substr(my $sec = $input, -6, 0, '.')
替换my $sec = $input / 1000000
,这样在它转到模块之前,它就是一个纯字符串操作,如果您确定它将是该字符串形式的话--但在这种规模下,这不太可能是一个问题。)
https://stackoverflow.com/questions/56384965
复制相似问题