Accueil > > > 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
Commentaires et avis
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>=$date_min AND date<=$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éussi à récupérer les titres des messages de phpBB, ainsi que l'auter, mais g pas réussi à 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
|
Derniers Blogs
INTéGRATION YAMMER ET SHAREPOINT ONLINE (OFFICE 365), éTAPE 1 .INTéGRATION YAMMER ET SHAREPOINT ONLINE (OFFICE 365), éTAPE 1 . par Patrick Guimonet
#Yammer Certains s'en sont déjà fait l'écho (ici en allemand par exemple : Yammer Integration in Office 365 Phase 1) ou bien sûr sur le blog SharePoint : Make Yammer your default social network in Office 365 en anglais. Mais c'e...
Cliquez pour lire la suite de l'article par Patrick Guimonet [DYNAMICS CRM] AJOUTER LES DOSSIERS DE CRM AU DOSSIER FAVORIS D'OUTLOOK[DYNAMICS CRM] AJOUTER LES DOSSIERS DE CRM AU DOSSIER FAVORIS D'OUTLOOK par bianca
Objectif
Pour aller plus rapidement dans les menus de Dynamics CRM depuis votre client CRM pour Outlook, vous pouvez utiliser le dossier des Favoris d'Outlook. En effet, par simple glisser/déplacer, vous pouvez déposer un éléme...
Cliquez pour lire la suite de l'article par bianca VISUAL STUDIO 2013VISUAL STUDIO 2013 par Etienne Margraff
Ahh, ENFIN ! c'est officiel, il va y avoir un VS et un TFS 2013. De nouvelles fonctionnalités qui vont à mon sens assoir la maturité de TFS qui est maintenant l'outil incontournable pour tout projet (.NET, mais pas seulement !). Si vous n'avez pas jet...
Cliquez pour lire la suite de l'article par Etienne Margraff CONFIGURER LA COLLATION SQL SERVER POUR SHAREPOINT CONFIGURER LA COLLATION SQL SERVER POUR SHAREPOINT par JeremyJeanson
Note : Je poste cet article à titre de pense-bête. Cela fait des années que je me trimballe avec une capture d'écran, car je ne me rappel jamais comment choisir la collation d'un SQL Server pour SharePoint. Pour SharePoint, il est conseillé de choisir la ...
Cliquez pour lire la suite de l'article par JeremyJeanson ETENDRE LE TEAM WEB ACCESS DE TFS 2012 - STEP 1: CRéATION DU PLUGINETENDRE LE TEAM WEB ACCESS DE TFS 2012 - STEP 1: CRéATION DU PLUGIN par Philess
Dans cet article nous allons créer un plugin installable sur le Team Web Access qui s'intègrera dans l'architecture du site et se chargera au moment où on le décidera.
Avant de lire ce billet et si cela n'est pas encore fait j...
Cliquez pour lire la suite de l'article par Philess
Logiciels
Nego Facturation (1.85)NEGO FACTURATION (1.85)Nego Facturation est un logiciel complet qui permet de gérer vos factures et devis très simplemen... Cliquez pour télécharger Nego Facturation Devis-Factures PHMSD (2.2.0.1)DEVIS-FACTURES PHMSD (2.2.0.1)Configuration minimale
Nécessite Windows™ 2000, XP, Windows 7, 8, Vista (Service Pack à... Cliquez pour télécharger Devis-Factures PHMSD WDmemoCode (2.0.0.1)WDMEMOCODE (2.0.0.1)WDmemoCode a été conçu pour aider les développeurs Windev à créer/compléter et conserver une base... Cliquez pour télécharger WDmemoCode ProtoMedic (4.0.0.11)PROTOMEDIC (4.0.0.11)ProtoMedic est un logiciel destiné principalement aux médecins généralistes.
ProtoMedic permet d... Cliquez pour télécharger ProtoMedic MyCurriculum 2011 (7.4.1.12)MYCURRICULUM 2011 (7.4.1.12)Rédigez votre Curriculum Vitae mais également ceux de votre famille ou de vos amis très facilemen... Cliquez pour télécharger MyCurriculum 2011
|