Как получить разницу в дате в Laravel, используя Carbon или PHP - PullRequest
0 голосов
/ 28 сентября 2019

Я пытаюсь получить разницу между двумя датами.Формат от API: Y-m-dTH:i:s.Изначально я хотел вывести что-то подобное.02h 10m но когда разница во времени слишком велика, мне пришлось переключиться на формат 01day 12hour 05minute.

Я пытался использовать $duration = 7600 ИЛИ $duration = 28800

{{gmdate('t', $duration)}}day {{gmdate('H', $duration)}}hour {{gmdate('i', $duration)}}minute

и {{gmdate('d', $duration)}}day {{gmdate('H', $duration)}}hour {{gmdate('i', $duration)}}minute

Это всегда возвращает дневное значение как 1, когда разница составляет всего 2 часа.

Ответы [ 3 ]

1 голос
/ 28 сентября 2019

Попробуйте функцию diff углерода

$past = now();
$future = now()->addHours(2);
$past->diff($future)->format('%dday %hhour %mminute');

Output

"0day 2hour 0minute"
0 голосов
/ 28 сентября 2019

Попробуйте это

  $start_date = new DateTime('2012-09-01 04:10:58');
  $since_start = $start_date->diff(new DateTime('2012-09-11 10:25:00'));
  echo $since_start->d.'days '.$since_start->h.'hours '.$since_start->i.'minutes';
0 голосов
/ 28 сентября 2019

Обязательно

use Carbon\Carbon;
use Carbon\CarbonInterval;

Конвертируйте даты API в форматированную дату, используя Carbon

$formatted_dt1=Carbon::parse('2019-09-26 00:00:00');
$formatted_dt2=Carbon::parse('2019-09-28 12:12:11');

$totalDuration = $formatted_dt1->DiffInSeconds($formatted_dt2);

echo CarbonInterval::seconds($totalDuration)->cascade()->forHumans();
// output :- 2 days 12 hours 12 minutes 11 seconds

Если вы хотите получить d ay, Minutes, Seconds тогда.

    $formatted_dt1=Carbon::parse('2019-09-26 00:00:00');
    $formatted_dt2=Carbon::parse('2019-09-28 00:00:00');

    $date_diff=$formatted_dt1->diffInDays($formatted_dt2);
    echo $date_diff.' Day '; //2 days


    $hours_diff = $formatted_dt1->diffInHours($formatted_dt2); 
    echo $date_diff.' Hours '; //48 Hours 


    $Minutesdiff = $formatted_dt1->diffInMinutes($formatted_dt2); 
    echo $Minutesdiff.' Minutes '; //2880 Minutes



    $seconddiff = $formatted_dt1->DiffInSeconds($formatted_dt2); 
    echo $seconddiff.' Seconds '; //172800  Seconds
    exit;
...