将存储的时间字符串与 DateTime('now') 进行比较

Comparing stored time string to DateTime('now')

我将时间作为字符串存储在我的数据库中...希望这不是我的问题,我需要将存储的 time/date 与当前的 time/date 进行比较并得到 days/hours/minutes.

以这种格式存储... 11-10 07:42 PM

我将该字符串分配给 $storedTime。

$storedTime = "11-10 07:42 PM";

获取当前时间...

$now = new DateTime('now');

$now->setTimezone(new DateTimeZone('America/Los_Angeles'));

$now = $now->format('m-d h:i A');

将我的变量转换为时间,如..

$time = new DateTime(strtotime($storedTime));

并格式化...

$time1 = $time->format('m-d h:i A');

尝试比较这两个时间,我得到一个错误,我仍在将字符串传递给 diff()

$interval = $time1->diff($now);

echo $interval->format('%s second(s)');

我尝试了很多不同的变体,我的脑子都炸了哈哈,请帮忙:)

当您在 DateTime class 上调用 ->format 方法时,您正在将对象转换为字符串。我相信这就是你的问题所在。

请参阅下面的示例,了解如何解决这个问题。您可以根据需要直接申请您的问题。

$storedTime = "11-10 07:42 PM";
$convertedTime = DateTime::createFromFormat("m-d h:i A", $storedTime);
$convertedTime->setTimezone(new DateTimeZone('America/Los_Angeles'));

$now = new DateTime('now');
$now->setTimezone(new DateTimeZone('America/Los_Angeles'));

$diff = $convertedTime->diff($now);
$diff_string = $diff->format('%s second(s)');

print($diff_string);