дата / время конвертируются во время с php - PullRequest
3 голосов
/ 01 июня 2010

Здравствуйте, в моей базе данных дата / время в этом формате

2010-06-01T18:20:25+0000

Я хотел бы повторить это время, прошедшее с этой даты / времени

например.

4 дня 3 часа 36 минут и 4 секунды

это возможно?

Ответы [ 5 ]

4 голосов
/ 01 июня 2010

Ниже приведена функция, которую я написал для этого. Не стесняйтесь использовать его.

/**
 * Returns rough (in largest single unit) time elapsed between two times.
 * @param int $iTime0  Initial time, as time_t.
 * @param int $iTime1  Final time, as time_t. 0=use current time.
 * @return string Time elapsed, like "5 minutes" or "3 days" or "1 month".
 *              You might print "ago" after this return if $iTime1 is now.
 * @author Dan Kamins - dos at axonchisel dot net
 */
function ax_getRoughTimeElapsedAsText($iTime0, $iTime1 = 0)
{
    if ($iTime1 == 0) { $iTime1 = time(); }
    $iTimeElapsed = $iTime1 - $iTime0;

    if ($iTimeElapsed < (60)) {
        $iNum = intval($iTimeElapsed); $sUnit = "second";
    } else if ($iTimeElapsed < (60*60)) {
        $iNum = intval($iTimeElapsed / 60); $sUnit = "minute";
    } else if ($iTimeElapsed < (24*60*60)) {
        $iNum = intval($iTimeElapsed / (60*60)); $sUnit = "hour";
    } else if ($iTimeElapsed < (30*24*60*60)) {
        $iNum = intval($iTimeElapsed / (24*60*60)); $sUnit = "day";
    } else if ($iTimeElapsed < (365*24*60*60)) {
        $iNum = intval($iTimeElapsed / (30*24*60*60)); $sUnit = "month";
    } else {
        $iNum = intval($iTimeElapsed / (365*24*60*60)); $sUnit = "year";
    }

    return $iNum . " " . $sUnit . (($iNum != 1) ? "s" : "");
}

Чтобы использовать эту функцию, вам необходимо сначала преобразовать ваше время в формат time_t (целое число #seconds с начала эпохи). Любая из этих функций PHP, вероятно, поможет с этим: http://php.net/strptime или http://php.net/strtotime.

2 голосов
/ 28 декабря 2011

Я изменил одну строку вышеуказанного кода для случая, когда он был опубликован менее минуты назад.

    function ax_getRoughTimeElapsedAsText($iTime0, $iTime1 = 0)
    {
    if ($iTime1 == 0) { $iTime1 = time(); }
    $iTimeElapsed = $iTime1 - $iTime0;

    if ($iTimeElapsed < (60)) {
        return "Less than a minute ago";
    } else if ($iTimeElapsed < (60*60)) {
        $iNum = intval($iTimeElapsed / 60); $sUnit = "minute";
    } else if ($iTimeElapsed < (24*60*60)) {
        $iNum = intval($iTimeElapsed / (60*60)); $sUnit = "hour";
    } else if ($iTimeElapsed < (30*24*60*60)) {
        $iNum = intval($iTimeElapsed / (24*60*60)); $sUnit = "day";
    } else if ($iTimeElapsed < (365*24*60*60)) {
        $iNum = intval($iTimeElapsed / (30*24*60*60)); $sUnit = "month";
    } else {
        $iNum = intval($iTimeElapsed / (365*24*60*60)); $sUnit = "year";
    }

    return $iNum . " " . $sUnit . (($iNum != 1) ? "s" : "") . " ago";
    }
1 голос
/ 02 июня 2010
function time_ago($timestamp, $granularity = 2) {
  $timestamp = time() - $timestamp;
  $units = array('1 year|%d years' => 31536000, 
                 '1 week|%d weeks' => 604800, 
                 '1 day|%d days' => 86400, 
                 '1 hour|%d hours' => 3600, 
                 '1 min|%d mins' => 60, 
                 '1 sec|%d secs' => 1
                );
  $output = '';
  foreach ($units as $key => $value) {
    $key = explode('|', $key);
    if ($timestamp >= $value) {
      $pluralized = floor($timestamp / $value) > 1 ? 
                    sprintf($key[1], floor($timestamp / $value)) : 
                    $key[0];
      $output .= ($output ? ' ' : '') . $pluralized;
      $timestamp %= $value;
      $granularity--;
    }
    if ($granularity == 0) {
      break;
    }
  }
  return $output ? $output : "Just now";
}

Это должно быть близко.

Редактировать: добавил эту строку: $ timestamp = time () - $ timestamp;

1 голос
/ 01 июня 2010

вы можете использовать func timediff прямо в вашей базе данных:

http://dev.mysql.com/doc/refman/5.1/en/date-and-time-functions.html#function_timediff

передайте первый параметр как дату, а второй как сейчас ()

0 голосов
/ 01 июня 2010

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

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...