使用PHP中的UNIX时间戳计算时间差

时间:2013-08-22 12:15:15

标签: php mysql datetime unix-timestamp

我有2个unix时间,一个是今天的日期,另一个是到期时间。

  • 今日时间:1377173245(2013-08-22 12:07:25)
  • 到期时间:1406303166(2014-07-25 15:46:06)

我想要实现的是计算剩余时间到期。在目前的情况下,它应该显示,11 months -- hours -- minutes -- seconds我没有找到任何好的解决方案来计算差异。我怀疑是否可以使用UNIX时间系统计算时差?

谢谢: - )

5 个答案:

答案 0 :(得分:4)

这就是您要找的内容:DateTime::diff

首先使用第一个日期创建对象:

$date = new DateTime('2013-08-22 12:07:25');

然后使用diff方法:

$diff = $date->diff(new DateTime('2014-07-25 15:46:06'));

现在,如果您打印$ diff变量,您将看到包含小时,分钟,日等值的数组。

答案 1 :(得分:2)

使用DateTime::diff

请参阅http://www.php.net/manual/fr/datetime.diff.php

上的文档

答案 2 :(得分:1)

尝试使用datetime::diff。以下是php.net文档中的示例:

<?php
$datetime1 = date_create('2009-10-11');
$datetime2 = date_create('2009-10-13');
$interval = date_diff($datetime1, $datetime2);
echo $interval->format('%R%a days');
?>

使用timespamp创建DateTime对象很容易。但是,此解决方案需要PHP 5.3 +。

答案 3 :(得分:0)

绝对有可能。但是,你会遇到几个月的问题,因为每个月都有不同的天数,所以我只会在几天,几小时,几分钟和几秒之内完成。

$days=($expiration-$today)/(60*60*24);
$hours=(($expiration-$today)/(60*60))%24; //the modulus operator, gets a remainder
$minutes=(($expiration-$today)/(60))%(60*60);
$seconds=($expiration-$today)/60;

如果您需要数月,您会发现使用date_diff()更容易。

答案 4 :(得分:0)

使用DateTime类:

示例:

$datetime1 = new DateTime();
$datetime2 = new DateTime('2014-07-25 15:46:06');
$interval = $datetime1->diff($datetime2);
echo $interval->format('%M months, %H hours, %I minutes, and %S seconds remaining ');

输出:

11 months, 21 hours, 44 minutes, and 20 seconds remaining