迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > PHP >

如何使用 PHP 计算两个日期之间的差

作者:迹忆客 最近更新:2023/03/10 浏览次数:

PHP 中有几种方法可以计算两个日期之间的差。本文将介绍如何使用<5.3 以下的 PHP 版本以及较新版本>5.3 的计算日期之间差异的方法。

使用 strtotime() 计算 5.3 以下 PHP 版本的两个日期之间的差异

strtotime() 将两个日期转换为 UNIX 时间,并从中计算出秒数。由此,用秒计算不同的方法会更容易。该函数接受英语的字符串参数,该参数显示日期时间的描述。

例:

$firstDate = "2019-01-01";
$secondDate = "2020-03-04";

$dateDifference = abs(strtotime($secondDate) - strtotime($firstDate));

$years  = floor($dateDifference / (365 * 60 * 60 * 24));
$months = floor(($dateDifference - $years * 365 * 60 * 60 * 24) / (30 * 60 * 60 * 24));
$days   = floor(($dateDifference - $years * 365 * 60 * 60 * 24 - $months * 30 * 60 * 60 *24) / (60 * 60 * 24));

echo $years." year,  ".$months." months and ".$days." days";

//output: 1 year, 2 months and 3 days

上例使用几个函数(如 abs()floor(),当然最主要的是 strtotime())来得出两个日期的差。

strtotime() 获取日期的 UNIX 秒值,并使用 abs() 获取第一个日期的绝对值。

函数 floor() 用于将秒数舍入到最接近的整数。

要获得年份,需要 365 天乘以 60 分钟,60 秒和 24 小时,然后将其除以差异。

要获得月份,需将 30 天乘以 60 分钟,60 秒和 24 小时,然后将其除以日期差乘以年份和 365 天,60 分钟,60 秒和 24 小时的差。

然后,要获得日期差,请乘以 60 分钟,60 秒和 24 小时,然后将其除以日期差的差,年,365 天,60 分钟,60 秒和 24 小时的乘积以及月,30 天的乘积,60 分 60 秒和 24 小时。

最后,将所有内容放到一个变量中以显示最终差异。

使用 PHP 5.3 及更高版本中的 DateTime()DateInterval() 的对象

此方法是一种面向对象的方式,用于获取两个日期之间的差值,这也是最简单的方法,因为它不需要手动计算日期,因此我们推荐在 PHP >5.3 版本中使用这种方法。

例:

$firstDate  = new DateTime("2019-01-01");
$secondDate = new DateTime("2020-03-04");
$intvl = $firstDate->diff($secondDate);

echo $intvl->y . " year, " . $intvl->m." months and ".$intvl->d." day"; 
echo "<br>";
// Total amount of days
echo $intvl->days . " days ";

//output: 1 year, 2 months and 1 day
//        428 days

在上面的示例中,与上面的使用 strtotime() 和更多其他函数和计算不同,DateTime()DateInterval() 对象使用起来更加容易。

首先,使用 new DateTime() 声明日期。然后,在第一个日期使用 DateInterval() 对象的 diff() 方法来获得差值的整数值,并将第二个日期作为参数传递。

最后,要获取年份,只需使用对象 y。使用 m 获取月份,使用 d 获取天数。

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

Pandas 通过 Groupby 应用变换

发布时间:2024/04/23 浏览次数:189 分类:Python

本教程演示了 Pandas Python 中与 groupby 方法一起使用的 apply 和 transform 之间的区别。

如何从 Pandas 的日期时间列中提取月份和年份

发布时间:2024/04/23 浏览次数:160 分类:Python

我们可以分别使用 dt.year()和 dt.month()方法从 Datetime 列中提取出年和蛾。我们还可以使用 pandas.DatetimeIndex.month 以及 pandas.DatetimeIndex.year 和 strftime()方法提取年份和月份。

如何获取 Pandas DataFrame 的行数

发布时间:2024/04/23 浏览次数:71 分类:Python

本教程介绍如何通过使用 shape,len()来获取 Pandas DataFrame 的行数,以及有多少行元素满足条件。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便