PHP Дата + дни - PullRequest
       61

PHP Дата + дни

0 голосов
/ 20 декабря 2018

Я получил что-то подобное в MyBB, и я хочу добавить 5 дней к дате ($ datetime1), причем один из них должен храниться в $ nowPlus5D.Кроме того, отобразите в переменной $ leeft, сколько осталось дней, часов, минут.разница между (день купил + 5 дней) - дата теперь

define("IN_MYBB", 1);
require_once "global.php";


$data_zakupu = $db->query("
    SELECT timestamp
    FROM ".TABLE_PREFIX."subs
    WHERE txn_id <> '' AND uid=".$mybb->user['uid']." ORDER BY lid DESC          LIMIT 1;
");


     $dat = $db->fetch_field($data_zakupu,"timestamp");
     $date_buy = date('d-m-Y H:i:s', $dat); // added h:i:s

    // Total bought
    echo '<br><hr>';
   echo 'Bought date - ' . $date_buy;
  echo '<br>';

 $datetime2 = new DateTime('now');
  $datetime1 = new DateTime($date_buy); 

 $interval = $datetime1->diff($datetime2);

  $nowPlus5D = $datetime1->add(new DateInterval('P5D'));
 echo '<hr><br>';
 echo 'Expiration date - ' . $nowPlus5D->format('%a days, %h hours, %i, minutes');
 echo '<br>';

 $leeft = $nowPlus5D->diff($datetime1);
 var_dump($leeft);
 echo '<br>';
 echo $left->format('%a days, %h hours, %i, minutes');

и я получил это

Bought date - 20-12-2018 18:20:48

Expiration date - %pm 25pm1848, %06 062018000000Tue, 25 Dec 2018 18:20:48 +010048, %20, 12201200000031Europe/Warsaw48
  object(DateInterval)#14 (15) { ["y"]=> int(0) ["m"]=> int(0) ["d"]=> int(0) ["h"]=> int(0) ["i"]=> int(0) ["s"]=> int(0) ["weekday"]=> int(0) ["weekday_behavior"]=> int(0) ["first_last_day_of"]=> int(0) ["invert"]=> int(0) ["days"]=> int(0) ["special_type"]=> int(0) ["special_amount"]=> int(0) ["have_weekday_relative"]=> int(0) ["have_special_relative"]=> int(0) }

Fatal error: Call to a member function format() on integer in /stackoverflow.php on line 42

1 Ответ

0 голосов
/ 20 декабря 2018

Ваша главная проблема в том, что вы путаете пару объектов.В частности, DateInterval с DateTime .Форматирование - это одна вещь, которая отличается.

<?php
$date_buy = '2018-12-15 10:05:22';

$datetime2 = new DateTime('now');
$datetime1 = new DateTime($date_buy); 

$interval = $datetime1->diff($datetime2);    
$nowPlus5D = $datetime1->add(new DateInterval('P5D'));

//THIS IS A DATETIME OBJECT, NOT AN INTERVAL! NOTE FORMAT `Y-m-d H:i:s`
echo 'Expiration date - ' . $nowPlus5D->format('d \d\a\y\s, H \h\o\u\r\s, i \m\i\n\u\t\e\s');



var_dump($nowPlus5D);
var_dump($datetime1);
// ^ Notice those are the same? A result of `$nowPlus5D = $datetime1->add(new DateInterval('P5D'));`

// and Intervals then are of course zeros...
$left = $nowPlus5D->diff($datetime1);
echo '<br>';
echo $left->format('%a days, %h hours, %i, minutes');

// could do this...
$left = $nowPlus5D->diff(new \DateTime);
echo $left->format('%a days, %h hours, %i, minutes');

В любом случае, думаю, что ваша основная путаница была в отношении двух типов объектов.Представь, что ты можешь взять это отсюда.

...