Я пытаюсь извлечь метку времени Unix из mysql и преобразовать его в метку времени ISO8601. Мне нужен он для форматирования даты в подобный Facebook (или подобный переполнению стека:) '30 минут назад' вместо того, чтобы отобразить точную дату и время. Кто-либо имел дело с ним?
$timestamp = '1268932078';
$iso8601 = date('c', $timestamp);
Но есть встроенные функции, которые помогут вам в этом, если вы не хотите создавать свои собственные, например: DateTime::diff.
Нравится Facebook Формат времени:
Функция разницы во времени, которая выводит прошедшее время в стиле facebook: 1 день назад или 4 месяца назад.
function nicetime($date)
{
if(empty($date)) {
return "No date provided";
}
$periods = array("second","minute","hour","day","week","month","year","decade");
$lengths = array("60","60","24","7","4.35","12","10");
$now = time();
$unix_date = strtotime($date);
if(empty($unix_date)) {
return "Bad date";
}
if($now > $unix_date) {
$difference = $now - $unix_date;
$tense = "ago";
} else {
$difference = $unix_date - $now;
$tense = "from now";
}
for($j = 0; $difference >= $lengths[$j] && $j < count($lengths)-1; $j++) {
$difference /= $lengths[$j];
}
$difference = round($difference);
if($difference != 1) {
$periods[$j].= "s";
}
return "$difference $periods[$j] {$tense}";
}
// convert timestamp to date ISO8601
$timestamp = date('c', '1268932078');
// convert to nice date
echo nicetime($timestamp); //40 years ago