2010-03-18 11 views
12

J'essaie d'extraire l'horodatage unix de mysql et de le convertir en horodatage ISO8601. J'en ai besoin pour mettre en forme la date sur facebook (ou stack-overflow-like :) '30 minutes ago 'au lieu d'afficher la date et l'heure exactes. Est-ce que quelqu'un a traité avec?Comment convertir un horodatage unix en horodatage ISO8601 en PHP?

+0

Voici une belle bibliothèque jQuery pour elle, est-il celui que vous utilisez? http://github.com/rmm5t/jquery-timeago – joar

Répondre

16
$timestamp = '1268932078'; 

$iso8601 = date('c', $timestamp); 

Mais il y a des fonctions intégrées pour vous aider si vous ne voulez pas rouler votre propre, .: DateTime::diff par exemple.

3

Facebook Like Format Heure:

Une fois la fonction de différence qui sorties le temps passé dans le style de facebook : il y a 1 jour, ou il y a 4 mois.

http://www.php.net/manual/en/function.time.php#89415

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 
+0

Cela ne répond pas à la question. – bdsl

+0

@ bdsl: vous avez raison mec, je n'ai pas lu la question aussi bien que je devrais, btw, j'ai mis à jour la réponse. merci de nous avoir signalé ... –

Questions connexes