打印正/负date_diff

时间:2018-01-24 22:57:32

标签: php mysql mysqli dateinterval

说我有这个:

$date1=date_create(date('H:I', strtotime('8:00')));
$date2=date_create(date('H:I', strtotime('18:00')));
$diff1=date_diff($date1,$date2);

echo $diff1->format("%h:%I");

输出10:00(小时),但现在我想比较一下:

$date3=date_create(date('H:I', strtotime('8:30')));
$date4=date_create(date('H:I', strtotime('17:45')));
$diff2=date_diff($date3,$date4);

echo $diff2->format("%h:%I");

输出9:15。那么,如何在$diff1$diff2之间设置差异和符号(如果它是否为负数)?我只是希望得到45分钟的消极(在这种情况下)。

2 个答案:

答案 0 :(得分:4)

如果差异为负数,您可以使用%r格式化打印:

$diff1 = date_diff(date_create(date('H:i', strtotime('20:00'))), date_create(date('H:i', strtotime('18:00'))));
echo $diff1->format("%r%H:%i"); // prints -02:00

$diff2 = date_diff(date_create(date('H:i', strtotime('8:30'))), date_create(date('H:i', strtotime('17:45'))));
echo $diff2->format("%r%H:%i"); // prints 09:15

更好的版本:

$diff1 = date_diff(DateTime::createFromFormat('H:i', '20:00'), DateTime::createFromFormat('H:i', '18:00'));
echo $diff1->format("%r%H:%i"); // prints -02:00

$diff2 = date_diff(DateTime::createFromFormat('H:i', '8:30'), DateTime::createFromFormat('H:i', '17:45'));
echo $diff2->format("%r%H:%i"); // prints 09:15

详细了解 DateTime

答案 1 :(得分:0)

想想这可能会:

someGlobalFunc