NAME
Time::Elapsed - Displays the elapsed time as a human readable string.
SYNOPSIS
use Time::Elapsed qw( elapsed );
$t = 1868401;
print elapsed( $t );
prints:
21 days, 15 hours and 1 second
If you set the language to turkish:
print elapsed( $t, 'TR' );
prints:
21 gün, 15 saat ve 1 saniye
DESCRIPTION
This module transforms the elapsed seconds into a human readable string. It can be used for (for example) rendering uptime
values into a human readable form. The resulting string will be an approximation. See the "CAVEATS" section for more information.
IMPORT PARAMETERS
This module does not export anything by default. You have to specify import parameters. :all
key does not include import commands
.
FUNCTIONS
elapsed
KEYS
:all
COMMANDS
Parameter Description
--------- -----------
-compile All available language data will immediately be compiled
and placed into an internal cache.
FUNCTIONS
elapsed SECONDS [, OPTIONS ]
SECONDS
must be a number representing the elapsed seconds. If it is false,0
(zero) will be used. If it is not defined,undef
will be returned.The optional argument
OPTIONS
is a either a string containing the language id or a hashref containing several options. These two codes are equal:elapsed $secs, 'DE'; elapsed $secs, { lang => 'DE' };
The hashref is used to pass extra options.
OPTIONS
lang
The optional argument language id, represents the language to use when converting the data to a string. The language section is really a standalone module in the Time::Elapsed::Lang::
namespace, so it is possible to extend the language support on your own. Currently supported languages are:
Parameter Description
--------- -----------------
EN English (default)
TR Turkish
DE German
Language ids are case-insensitive. These are all same: en
, EN
, eN
.
weeks
If this option is present and set to a treu value, then you'll get "weeks" instead of "days" in the output if the output has a days value between 7 days and 28 days.
CAVEATS
The calculation of the elapsed time is only an approximation, since these values are used internally:
1 Day = 24 Hour 1 Month = 30 Day 1 Year = 365 Day
See "How Datetime Math is Done" in DateTime for more information on this subject. Also see
in_units()
method in DateTime::Duration.This module' s source file is UTF-8 encoded (without a BOM) and it returns UTF-8 values whenever possible.
Currently, the module won't work with any perls older than 5.6 because of the UTF-8 encoding and the usage of utf8 pragma. However, the pragma limitation can be by-passed with a
%INC
trick under 5.005_04 (tested) and can be used with english language (default behavior), but any other language will probably need unicode support.
SEE ALSO
PTools::Time::Elapsed, DateTime, DateTime::Format::Duration, Time::Duration.