begin process at 2013 06 20 03:26:46
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Date / Heure

 > CALCUL DU TEMPS ÉCOULÉ ENTRE 2 DATES

CALCUL DU TEMPS ÉCOULÉ ENTRE 2 DATES


 Information sur la source

 Description

Vous lui fournissez deux dates et il vous renvoie le temps écoulé entre la première date et la deuxième en nombre de jours nombre d'heures nombre de minutes et nombre de secondes. Source largement commentée

Source

  • function temps_ecoule($datedebut,$datefin)
  • {
  • // PAR HERVE SIGAP (DOUALA CAMEROUN)
  • // DICTIONNAIRE DES VARIABLES UTILISEES
  • // ______________________________________________________________________________________________
  • //| VARIABLE | DEFINITION |
  • // ______________________________________________________________________________________________
  • //| $datedebut | Date de début fournie en variable à la fonction |
  • //| $datefin | Date de fin de fournie en variable à la fonction |
  • //| $dd | Date de début interne à la fonction |
  • //| $df | Date de fin interne à la fonction |
  • //| $td | Heure de début interne à fonction |
  • //| $tf | Heure de fin interne à fonction |
  • //| $jd | Jour début |
  • //| $md | Mois début |
  • //| $ad | Année début |
  • //| $pd | Position Départ |
  • //| $jf | Jour Fin |
  • //| $mf | Mois Fin |
  • //| $af | Année Fin |
  • //| $pf | Position Fin |
  • //| $hd | Heure début |
  • //| $mid | Minute début |
  • //| $sd | Seconde début |
  • //| $tsd | Timestamp Début |
  • //| $hf | Heure Fin |
  • //| $mif | Minute Fin |
  • //| $sf | Second Fin |
  • //| $tsf | Timestamp Fin |
  • //| $ts | Différence Timestamp début et Timestamp fin |
  • //| $nbj | Nombre de jours |
  • //| $nbh | Nombre d'heures |
  • //| $nbm | Nombre de minutes |
  • //| $nbs | Nombre de secondes |
  • //| $texte | Texte affiché en sortie de fonction |
  • //_______________________________________________________________________________________________
  • if ($datedebut=='') {
  • $texte="impossible de démarrer la fonction sans la date de début";
  • } else {
  • if ($datefin!='') {
  • list($dd, $td) = explode(' ', $datedebut); // Séparation date et heure début
  • list($df,$tf) = explode(' ',$datefin); // Séparation date et heure fin
  • // Traitement date de début et Traitement Heure début
  • list($jd, $md, $ad) = explode('-', $dd); // Explosion date debut
  • $pd = mktime(0,0,0,$md,$jd,$ad); // structuration date debut
  • list($hd,$mid,$sd) = explode(':',$td); // Explosion heure début
  • // Traitement date de fin et Traitement Heure fin
  • list($jf,$mf,$af) = explode('-',$df); // Explosion date fin
  • $pf = mktime(0,0,0,$mf,$jf,$af); // structuration date fin
  • list($hf, $mif, $sf) = explode(":", $tf); // Explosion heure fin
  • //Structurations heures minutes et secondes
  • $tsd = mktime ($hd, $mid, $sd, 1, 1, 1970); // structuration heure debut
  • $tsf = mktime ($hf, $mif, $sf, 1, 1, 1970); // structuration heure fin
  • $ts = abs($tsf - $tsd);
  • // Extraction des valeurs attendues du Timestamp $ts
  • $nbj=abs($pf - $pd)/86400; // Nombre de jours écoulés
  • $nbh = floor($ts/3600); // Nombre d'heures écoulées
  • $ts = $ts - ($nbh*3600); // Soustrations du nombre de secondes définissables comme heure du total de secondes existant
  • $nbm = $ts/60; //Division de ce nombre de secondes par 60 pour en extraire celles définissables comme minute= Nombre de minutes écoulées
  • $nbm=floor($nbm); // Extraction Partie entière de la valeur nombre de minutes
  • $nbs=$ts-($nbm*60); //Soustrations du nombre de secondes définissables comme minutes du total de secondes restant : Le reste = nombre de secondes
  • if ($nbj==0) { // Si nombre jours =0
  • if ($nbh==0) { // Si nombre heures =0
  • if ($nbm==0) { // Si nombre minutes =0
  • $texte= $nbs." sec"; // Affichage secondes seulement
  • }else {
  • $texte= $nbm." min ".$nbs." sec"; // Affichage minutes et secondes
  • }
  • } else {
  • $texte= $nbh." hr ".$nbm." min ".$nbs." sec"; // Affichage heures, minutes et secondes
  • }
  • } else {
  • $texte= $nbj." j ".$nbh." hr ".$nbm." min ".$nbs." sec"; // Affichage jour, heure, minutes et secondes
  • }
  • } else { // Si date fin vide
  • $texte="processus en cours...";
  • } // Fin test existence date de fin
  • return $texte; // Renvoi Texte à afficher
  • } // Fin test existence date de début
  • } // Fin fonction
function temps_ecoule($datedebut,$datefin)
{
// PAR HERVE SIGAP (DOUALA CAMEROUN)
// DICTIONNAIRE DES VARIABLES UTILISEES
// ______________________________________________________________________________________________
//| VARIABLE        | DEFINITION                                                                |
// ______________________________________________________________________________________________
//|	$datedebut		|	Date de début fournie en variable à la fonction		|
//|	$datefin		|	Date de fin de fournie en variable à la fonction	|
//|	$dd			|	Date de début interne à la fonction			|
//|	$df			|	Date de fin	 interne à la fonction			|
//|	$td			|	Heure de début interne à fonction			|
//|	$tf			|	Heure de fin interne à fonction				|
//|	$jd			|	Jour début						|
//|	$md			|	Mois début						|
//|	$ad			|	Année début						|
//|	$pd			|	Position Départ					        |
//|	$jf			|	Jour Fin					        |
//|	$mf			|	Mois Fin						|
//|	$af			|	Année Fin						|
//|	$pf			|	Position Fin						|
//|	$hd			|	Heure début						|
//|	$mid			|	Minute début						|
//|	$sd			|	Seconde début						|
//|	$tsd			|	Timestamp Début						|
//|	$hf			|	Heure Fin						|
//|	$mif			|	Minute Fin						|
//|	$sf			|	Second Fin						|
//|	$tsf			|	Timestamp Fin						|
//|	$ts			|	Différence Timestamp début et Timestamp fin		|
//|	$nbj			|	Nombre de jours						|
//|	$nbh			|	Nombre d'heures						|
//|	$nbm			|	Nombre de minutes					|
//|	$nbs			|	Nombre de secondes					|
//|	$texte			|	Texte affiché en sortie de fonction			|
//_______________________________________________________________________________________________

if ($datedebut=='') {
	$texte="impossible de démarrer la fonction sans la date de début";
} else {
if ($datefin!='') {
list($dd, $td) = explode(' ', $datedebut); // Séparation date et heure début
list($df,$tf) = explode(' ',$datefin); // Séparation date et heure fin

// Traitement date de début et Traitement Heure début
list($jd, $md, $ad) = explode('-', $dd); // Explosion date debut
$pd = mktime(0,0,0,$md,$jd,$ad); // structuration date debut
list($hd,$mid,$sd) = explode(':',$td); // Explosion heure début


// Traitement date de fin et Traitement Heure fin
list($jf,$mf,$af) = explode('-',$df); // Explosion date fin
$pf = mktime(0,0,0,$mf,$jf,$af);  // structuration date fin
list($hf, $mif, $sf) = explode(":", $tf); // Explosion heure fin

//Structurations heures minutes et secondes
$tsd = mktime ($hd, $mid, $sd, 1, 1, 1970); // structuration heure debut
$tsf = mktime ($hf, $mif, $sf, 1, 1, 1970); // structuration heure fin
$ts = abs($tsf - $tsd);


// Extraction des valeurs attendues du Timestamp $ts
$nbj=abs($pf - $pd)/86400; // Nombre de jours écoulés
$nbh = floor($ts/3600); // Nombre d'heures écoulées
$ts = $ts - ($nbh*3600); // Soustrations du nombre de secondes définissables comme heure du total de secondes existant
$nbm = $ts/60;  //Division de ce nombre de secondes par 60 pour en extraire celles définissables comme minute= Nombre de minutes écoulées
$nbm=floor($nbm); // Extraction Partie entière de la valeur nombre de minutes
$nbs=$ts-($nbm*60); //Soustrations du nombre de secondes définissables comme minutes du total de secondes restant : Le reste = nombre de secondes

if ($nbj==0) { // Si nombre jours =0
	if ($nbh==0) { // Si nombre heures =0
		if ($nbm==0) { // Si nombre minutes =0
			$texte= $nbs." sec"; // Affichage secondes seulement
		}else {
			$texte= $nbm." min ".$nbs." sec"; // Affichage minutes et secondes
		}
	} else {
	$texte= $nbh." hr ".$nbm." min ".$nbs." sec"; // Affichage heures, minutes et secondes
	}
} else {
	$texte= $nbj." j ".$nbh." hr ".$nbm." min ".$nbs." sec"; // Affichage jour, heure, minutes et secondes
}
} else { // Si date fin vide
$texte="processus en cours...";
} // Fin test existence date de fin
return $texte; // Renvoi Texte à afficher
} // Fin test existence date de début
} // Fin fonction

 Conclusion

Cette fonction m'a servi à calculer le temps de connexion d'un utilisateur de mon site intranet. C'est pourqoui vous verez des renvois du genre 'processus en cours..." Toutefois, vous pouvez personnaliser les tests conditionnels et les messages sortants.


 Sources de la même categorie

CALCUL NOMBRE JOUR OUVRABLE (JOUR FERIER) ENTRE 2 DATES par lunnorey
Source avec Zip DATE ET HEURE EN PHP par JejeScript
Source avec Zip COMPTEUR 2 EN 1 AVEC IP par floflode69
Source avec Zip Source avec une capture CALENDRIER SIMPLE AVEC AFFICHAGE AUTOMATIQUE EN ROUGE DES JO... par BURAK77
Source avec une capture AGENDA GRAPHIQUE SIMPLE (DÉBUTANT) À INTÉGRER par NicomakM

 Sources en rapport avec celle ci

Source avec Zip AFFICHAGE AUTOMATIQUE PERSONNALISABLE À PARTIR D'UNE DATE DO... par aurelWeb
Source avec Zip Source avec une capture CALENDRIER SIMPLE AVEC AFFICHAGE AUTOMATIQUE EN ROUGE DES JO... par BURAK77
CLASSE FEUILLE DE TEMPS PHP5 par guill76
TEMPS ÉCOULÉ (DURÉE) ENTRE 2 DATES SOUS FORME LITTÉRAL NATUR... par olid
AFFICHAGE DU DÉCOMPTE D'UNE DATE PAR RAPPORT AVEC LA DATE AC... par GREGPUNK

Commentaires et avis

Commentaire de Evangun le 29/07/2006 00:02:36

Salut,
j'aime bien la méthode avec laquelle tu as écrit cette fonction, c'est très clair.
Juste un truc : pourquoi as-tu séparé les heures et les jours dans ton mktime ?
tu aurais pu écrire par exemple $pf = mktime($td,$mid,$sd,$mf,$jf,$af); comparer tes timestamp en divisant par les jours et prendre le reste de la division pour les heures.

au fait ça parait évident mais il faut préciser pour les débutants que les dates fournies à ta fonction sont de type "31-12-2006 22:12:59"
à+

Commentaire de Sannazzarotiti le 29/07/2006 10:37:39

pk faire tout sa.

Tu enrengistre le timestamps de depart, tu le soustrait au timestamps de fin sa te fait le nombre de seconde. apres avec des division ta le temps qu'il c'est passer non?

pk faire tout ce code

Commentaire de Evangun le 29/07/2006 12:17:33

c'est ce qu'il a fait...
par contre, il faudrait indenter partout : les } qui traînent à la fin sans qu'on sache ce qu'ils referment, c'est pas génial.

Commentaire de jeca le 30/07/2006 13:43:05

Bonjour,

Essaie ton code avec ces valeurs :
$dateDeb = '01-07-2006 00:00:00';
$dateFin = '02-07-2006 10:25:01';

Résultat :
Warning: mktime(): Windows does not support negative values for this function in c:\easyphp\www\essai\toto.php on line 57
1 j 9 hr 25 min 2 sec

Pourquoi avoir utilisé ce format de date qui ne correspond à rien ni en php ni dans mysql ? Si tu t'en sert pour calculer des temps de connexion, ça suppose que tu récupère l'heure système, que tu es obligé de transformer dans ce format pour le transformer de nouveau dans ta fonction. Ce n'est quand même pas le plus rapide ni le plus simple.

Ensuite, tous ces 'if' imbriqués rendent le code tout à fait illisible, indigeste et difficile à débugger : la génération du texte de retour ne fonctionne pas. Essaie avec ça :
$dateDeb = '01-07-2006 10:25:01';
$dateFin = '02-07-2006 10:25:01';

Utiliser des noms de variables significatifs ne nuit pas (Ex : $dateDeb au lieu de $dd, $tempsDeb au lieu de $td).

Lorsque des lignes de codes sont utilisées plusieurs fois, autant les déporter dans une fonction, ça éclaircit le code, et la mise au point est plus simple.

A éviter aussi :
    $texte="impossible de démarrer la fonction sans la date de début";
Préférer :
    $texte='impossible de démarrer la fonction sans la date de début';
car php analyse les chaînes encadrées par des double-quotes afin de rechercher les éventuelles variables à évaluer. Dans le cas présent, il n'y en a pas, donc, il travaille pour rien.

En fin, bref, voici comment j'autrais fait :

<?php
function creeMsg(&$texte, $valeur, $libelle)
{
//-- passage du message par référence, donc pas besoin de return ---------
if ($valeur > 0)
{
$pluriel = ($valeur == 1) ? '' : 's';
$texte .= $valeur . ' ' . $libelle . $pluriel . ' ';
}
}

function getTimeStamp($chaine)
{
list($date, $temps) = explode(' ', $chaine); // Séparation date et heure
list($jour, $mois, $annee) = explode('-', $date); // Explosion date
list($heure, $minute, $seconde) = explode(':',$temps); // Explosion heure

return mktime($heure, $minute, $seconde, $mois, $jour, $annee);
}

function temps_ecoule($datedebut,$datefin)
{
if ($datedebut == '') return "impossible de démarrer la fonction sans la date de début";
if ($datefin == '') return "processus en cours...";

$debut = getTimeStamp($datedebut);
$fin = getTimeStamp($datefin);
$duree = $fin - $debut;

// Extraction des valeurs attendues du Timestamp
$nbjour = floor($duree / 86400); // Nombre de jours écoulés
$reste = $duree % 86400;
$nbheure = floor($reste / 3600); // Nombre d'heures écoulées
$reste = $reste % 3600;
$nbminute = floor($reste / 60); // Nombre de minutes écoulées
$nbseconde = $reste % 60; // Nombre de secondes écoulées

$texte = '';
creeMsg($texte, $nbjour, 'jour');
creeMsg($texte, $nbheure, 'heure');
creeMsg($texte, $nbminute, 'minute');
creeMsg($texte, $nbseconde, 'seconde');

return $texte; // Renvoi Texte à afficher
} // Fin fonction
$dateDeb = '01-07-2006';
$dateFin = '02-07-2006 10:25:01';

echo temps_ecoule($dateDeb, $dateFin) . '<br>';
?>

Et avec une date normalement constituée :

<?php
function creeMsg(&$texte, $valeur, $libelle)
{
//-- passage du message par référence, donc pas besoin de return ---------
if ($valeur > 0)
{
$pluriel = ($valeur == 1) ? '' : 's';
$texte .= $valeur . ' ' . $libelle . $pluriel . ' ';
}
}

function temps_passe($dateDebut, $dateFin)
{
//-- si dateDebut = '' on l'initialise avec la date courante -------------
if ($dateDebut == '') $dateDebut = date('Y-m-d H:i:s');
//-- si dateFin = '' on l'initialise avec la date courante ---------------
if ($dateFin == '') $dateFin =  date('Y-m-d H:i:s');

if ($dateDebut > $dateFin) return 'La date début doit être < la date fin';

$duree = strtotime($dateFin) - strtotime($dateDebut);
if ($duree == 0) return 'pas de différence';

$jour = floor($duree / 86400);
$reste = $duree % 86400;
$heure = floor($reste / 3600);
$reste = $reste % 3600;
$minute = floor($reste / 60);
$seconde = $reste % 60;

$texte = '';
creeMsg($texte, $jour, 'jour');
creeMsg($texte, $heure, 'heure');
creeMsg($texte, $minute, 'minute');
creeMsg($texte, $seconde, 'seconde');

return $texte;
}

$dateDeb = '2006-07-01';
$dateFin = '2006-07-02 10:25:01';

echo temps_passe($dateDeb, $dateFin) . '<br>';
?>

Commentaire de pagis78 le 31/07/2006 10:47:51

Merci à tous pour ces commentaires, ca me permet d'améliorer mes codes et leur optimisation.

Commentaire de coolboy78 le 20/11/2007 09:22:43

Ce code ne fonctionne !

exemple avec ca :
temps_ecoule("2007-11-19 23:57:01","2007-11-20 00:05:02");

Warning: mktime(): Windows does not support negative values for this function in c:\program files\easyphp1-8\www\heure.php on line 54

366 j 22 hr 57 min 2 sec !!!!!!!

Il n'y a que quelques minutes qui sépare ces 2 date !!

Commentaire de KaTSuotlz le 24/07/2008 21:26:29

...

De Evangun :
<i>au fait ça parait évident mais il faut préciser pour les débutants que les dates fournies à ta fonction sont de type "31-12-2006 22:12:59"</i>

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

calcul la durée d'une SESSION [ par goyes ] slt,j'ai crée une session sur ma page .D'abord j'ai remarqué que la session est detruite que lorsque la fenetre du navigateur de l'internaute est tota compter le nombre de dimanche sur un intervalle de date [ par desrimaisd ] salut,je voudrais savoir si kelk'un connaitrait un moyen de savoir combien il y a de dimanche (en fait d'un jour en particulier, c pareil pour les aut En fonction du temps ? [ par cedd ] Bonjour!Mon problème se situe au niveau de la fonction du temps.Je sais que pour récupérer la date systeme, il faut utiliser:$date_du_jour = date("d-m calcul affiché en temps reel sur la page [ par laubro ] Bonjour,une question, j'ai un form avec une date de debut et une date de fin, ensuite quand j'envoi le form j'ai le calcul du nbr de jours entre les d Select des champs ayant une date qui appartient a un intervalle [ par sephiroth1020 ] Je souhaite faire un SELECT entre deux dates : genre SELECT * FROM transaction date&gt;=$date_min AND date&lt;=$date_max Cette expression ne marche Récupérer la date et temps des topics de phpBB [ par ala_daly ] Salut tt le monde, g r&#233;ussi &#224; r&#233;cup&#233;rer les titres des messages de phpBB, ainsi que l'auter, mais g pas r&#233;ussi &#224; trouver Date et heure [ par MAsterC ] Bonjour,Je suis à la recherche de quelques chose du genre...Je veux calculé le temps écoulé avec le temps d'aujourd'hui et le faire affichez d'une cer Temps en heure entre deux date/heure [ par Eliays ] Bonjour, comment calculer le nombre d'heure entre deux date? Par exemple j'ai 01-10-2008/22:00 et 02-10-2008/15:00. Voila je ne vois pas comment d calcul de la durée entre 2 heures - fonction date [ par YarbY ] Bonjour, Est ce normal que date("H:i",0) donne 1:00 ?? Je cherche à faire une soustraction entre 2 heures, pour calculer une durée et j'ai un ecart de Ajouter un intervalle de jours à une date [ par helphp ] Bonjour, comme le sujet l'indique, j'aimerais ajouter à mon code une intervalle de 7 jours à une date. j'ai ceci comme début: [code=php]$featured7d


Nos sponsors


Sondage...

CalendriCode

Juin 2013
LMMJVSD
     12
3456789
10111213141516
17181920212223
24252627282930

Consulter la suite du CalendriCode

Photothèque

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,593 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales