所以我有一个 30:13(分钟:秒)格式的播客长度数组,我想首先将其转换为有效的 UNIX 时间戳,然后将此时间戳格式化为可读的内容,例如"30 分 13 秒"。
我的转换为时间戳函数如下所示:
public function duration($str) {
$a = explode(':', $str);
$v = (($a[0]*60)+$a[1]);
return $v;
}
当我尝试用date('H:i:s', $v)
格式化它时,问题就出现了,它会产生像"17:35:50"这样的数字,而地狱里没有办法播客长达 17 个小时。我做错了什么?
UNIX 时间戳不是用来计算持续时间的,它们将特定时间表示为自纪元(1970 年初)以来的秒数。如果将非常低的值传递给需要时间戳的函数(如 date()
),则将获得 1970 年代初的日期。您必须手动进行时间格式化。
编辑:请注意,如果您住在GMT时区,您将获得预期的结果。这是因为date()
在计算从时间戳生成的日期时会考虑您当前的时区。
只需将其格式化为可读字符串即可。
$duration = '30:13';
list($min, $sec) = explode(':', $duration);
echo "{$min}mins {$sec}s"; // 30mins 13s
这应该可以完成您想要的工作。时间戳是不同的,请参阅 http://en.wikipedia.org/wiki/Timestamp
// $str has the format 'mm:ss'
public function duration($str) {
list($min, $sec) = explode(':', $str);
return $min . ' mins ' . $sec . ' sec';
}
使用简单正则表达式
function duration($str)
{
return preg_replace('/^([0-9]{2})':([0-9]{2}$)/', '$1 mins $2s', $str);
}
echo duration("30:33");
输出
30 mins 33s
希望这对你有帮助。谢谢!!
你可以尝试hh:mm:ss
。list($hours,$mins,$secs) = explode(':', $yourtime);
echo $hours.' hours '.$mins .'minuts'. $secs .'seconds';
愿这行得通
Unix 时间戳为您提供从 1970 年 1 月 1 日 00:00:00 开始经过的秒数,但不是时间段。
为了完成你的任务,我会做:
$str = '30:13';
function duration($str) {
$a = explode(':', $str);
$hours = floor($a[0] / 60);
$minutes = $a[0] - $hours * 60;
$seconds = $a[1];
$result = '';
if($hours) {
$result .= "$hours hours ";
}
if($minutes) {
$result .= "$minutes minutes ";
}
return "$result$seconds seconds";
}
var_dump(duration($str));
您可以使用 DateInterval 对象。
function getInterval($durationString) {
$parts = explode(':', $durationString);
$min = $parts[0];
$sec = $parts[1];
$interval = new DateInterval("PT{$min}M{$sec}S");
return $interval;
}
$interval = getInterval('30:12');
echo $interval->format('%imins %ss');
我假设您使用的是只有分钟和秒的持续时间时间格式,当然,如果您还需要小时,您可以修改代码。