Calcul le nombre de jours non-ouvrés entre 2 dates

  Information

Fonction pour récupérer le nombre de jours non-ouvrés

Jours fériés en France et week end ( samedi et dimanche ) entre deux dates au format timestamp.

Ce script peut avoir des dates sur des années différentes, ou sur plusieurs années de différence. La classe!!

  code source classé dans  Dates - Heures

 
 01    
 02    
 03    
 04    
 05    
 06    
 07    
 08    
 09    
 10    
 11    
 12    
 13    
 14    
 15    
 16    
 17    
 18    
 19    
 20    
 21    
 22    
 23    
 24    
 25    
 26    
 27    
 28    
 29    
 30    
 31    
 32    
 33    
 34    
 35    
 36    
 37    
 38    
 39    
 40    
 41    
 42    
 43    
 44    
 45    
 46    
 47    
 48    
 49    
 50    
 51    
 52    
 53    
 54    
 55    
 56    
 57    
 58    
 59    
 60    
 61    
 62    
 63    
 64    
 65    
 66    
 67    
 68    
 69    
 70    
 71    
 72    
 73    
 74    
 75    
 76    
 77    
 78    
 79    
 80    
 81    
 82    
 83    
 84    
 85    
 86    
 87    
 88    
 89    
 90    
 91    
 92    
 93    
 94    
 95    
 96    
 97    
 98    
 99    
 100    
 101    
 102    
 103    
 104    
 105    
 106    
 107    
 108    
 109    
 110    
 111    
 112    
 113    
 114    
 115    
 116    
 117    
 118    
 119    
 120    
 121    
 122    
 123    
 124    
 125    
 126    
                               
<?php
/*---------------------------------------------------------------*/
/*
    Titre : Calcul le nombre de jours non-ouvrés entre 2 dates                                                           
                                                                                                                          
    URL   : https://phpsources.net/code_s.php?id=644
    Auteur           : seanron                                                                                            
    Website auteur   : http://seanron.free.fr                                                                             
    Date édition     : 12 Mai 2011                                                                                        
    Date mise à jour : 13 Aout 2019                                                                                      
    Rapport de la maj:                                                                                                    
    - fonctionnement du code vérifié                                                                                    
*/
/*---------------------------------------------------------------*/

    function leap_year($year){
        return date("L"mktime(00000$year));
    }
//calcul des jours non-ouvrés
    function sort_closed_days$timestamp1$timestamp2 )
    {

        //dates en jours de l'année ( depuis le 1er jan )
        $datedate("z"$timestamp1) ; // date de depart
        $datedate("z"$timestamp2) ; //date d'arrivée
        
        $day_stamp 86400 //(3600 * 24 ); // un journée en timestamp
    
        //années des deux dates
        $year1        date("Y"$timestamp1) ;
        $year2        date("Y"$timestamp2) ;
        
        
        $num 0//nombre de jours feries a compter sur la duree totale
        $counter 0
// la durée entre les deux date, sur l'année en cours ou sur plusieurs années
        
        $year $year1// l'année en cours ( defaut : $year1 )
        
        
//on calcule le nombre de jours de difference entre les deux dates, en tenant
// compte des années
        while ( $year <= $year2 )
        {

            //on liste les jours fériés de l'année en cours    
            $easterDate        easter_date($year) ;
            $easterDay        date('j'$easterDate) ;
            $easterMonth    date('n'$easterDate) ;
            $easterYear        date('Y'$easterDate) ;
        
            
//le tableau sort les jours fériés de l'année depuis le premier janvier
            $closed array
            (
                // dates fixes
                date("z"mktime(0001,  1,  $year))+1,  // 1er janvier
                date("z"mktime(0005,  1,  $year))+1,  
// Fête du travail
                date("z"mktime(0005,  8,  $year))+1,  
// Victoire des alliés
                date("z"mktime(0007,  14$year))+1,  // Fête nationale
                date("z"mktime(0008,  15$year))+1,  // Assomption
                date("z"mktime(000111,  $year))+1,  // Toussaint
                date("z"mktime(0001111$year))+1,  // Armistice
                date("z"mktime(0001225$year))+1,  // Noel

                // Dates basées sur Paques
                date("z"mktime(000$easterMonth$easterDay 2,  
$easterYear))+1// lundi de Paques
                date("z"mktime(000$easterMonth$easterDay 40
$easterYear))+1// Ascension
                date("z"mktime(000$easterMonth$easterDay 50
$easterYear))+1// Dimanche Pentecote
                date("z"mktime(000$easterMonth$easterDay 51
$easterYear))+// Lundi de Pentecote
            );

            
//si c'est la première année -> on commence par la date de depart; le compteur
// compte les jours jusqu'au 31dec
            if( $year == $year1 && $year $year2 ){ $i $date1$counter +=  (
 365+leap_year($year) ) - $date; } ;

            
// si c'est ni la première ni la derniere année -> on commence au premier
// janvier; le compteur compte tous les jours de l'année
            if( $year $year1 && $year $year2 ){ $i date("z"mktime(00
01,  1,  $year));  $counter += 365+leap_year($year); } ;

            
// si c'est la dernière année -> on commence au premier janvier; le compteur
// va
// jusqu'a la date d'arrivée
            if( $year == $year2 && $year $year1 ){ $i date("z"mktime(00,
 01,  1,  $year)); $counter += $date; } ;
            
            // si les deux dates sont dans la même année
            if( $year == $year1 && $year == $year2 ){ $i $date1$counter += 
$date; } ;
            
            //on boucle les jours sur la période donnée pour cette année
            while ( $i $counter )
            {
                //on compte chaque jour férié
                if( in_array($i$closed) ) $num++;
                
                //on compte chaque samedi
                if( date("w"$timestamp1 $i $day_stamp) == 5  && !in_array(
$i$closed) ) $num++ ;
                    
                //et chaque dimanche
                if( date("w"$timestamp1 $i $day_stamp) == && !in_array(
$i$closed) ) $num++ ;
                
                $i++;
            }
        
            $year++ ; // on incremente l'année
        }

    return $num;
    }
?>

Exemple :

 
 01    
 02    
 03    
 04    
 05    
 06    
 07    
 08    
                                
<?php
    $date1 mktime(00001252018);
    $date2 mktime(00001252019);
    echo sort_closed_days($date1$date2);
    // Affiche : 208
?>

          Fonctions du code - Doc officielle PHP

   php.net   Description Versions PHP OUTIL
   array Crée un tableau PHP 4, PHP 5, PHP 7, PHP 8
   date Formate une date/heure locale PHP 4, PHP 5, PHP 7, PHP 8
   easter_date Retourne un timestamp UNIX pour Pâques, à minuit pour une année donnée PHP 4, PHP 5, PHP 7, PHP 8
   in_array Indique si une valeur appartient à un tableau PHP 4, PHP 5, PHP 7, PHP 8
   mktime Retourne le timestamp UNIX d'une date PHP 4, PHP 5, PHP 7, PHP 8
   return Retourne le controle du programme au module appelant. PHP 4, PHP 5, PHP 7, PHP 8

   Dites merci aux auteurs pour leurs travail, ça ne coûte rien et ça fait toujours plaisir wink

[5]

  • avatar

    Invité

    04 Oct 2012 à 16:21

    bonjour, Merci pour ce code, je m'en suis servie pour calculer le nombre de jours ouvrés entre 2 dates. Cependant j'ai du faire beaucoup de modifications pour que celà fonctionne parfaitement chez moi. Mais ça m'a au moins servi de base car je ne connaissais pas les formules pour trouver les jours fériés par exemple. De plus je voulais signaler que la fonction

        function leap_year($year){         return date("L"mktime(00000$year));     }

    n'est pas correcte. J'ai l'impression que ça prend l'année précédente car cette fonction renvoie 0 pour 2012 et 1 pour 2013, en fait il faut faire :
        function leap_year($year){         return date("L"mktime(000, 1, 1$year));     } 

    Et aussi, même si ça a déjà été dit : la fonction date() avec "w" comme paramètre de format renvoie le jour  au format numérique de  0 (pour dimanche) à 6 (pour samedi).
    Bref y'a pas mal de modifs a faire dans ce code mais grand Merci quand même.

  • avatar

    Invité

    10 Juil 2012 à 11:27

    ce qui m'embête un peu dans ce code, c'est l'initialisation du tableau dans la boucle while.... J'ai repris ce programme pour afficher tous les dimanches et jours fériés entre deux dates, et j'ai initialisé le tableau $closed à l'extérieur de la boucle. Ca marche parfaitement. Merci !!

  • avatar

    Invité

    10 Mai 2012 à 09:49

     La fonction ne marche pas du tout, entre le 05/01/2012 et le 10/01/2012, pour elle il n'y a aucun samedi ni dimanche

  • avatar

    Invité

    12 Oct 2011 à 14:55

    Bonjour,

    Il y a une petite erreur dans ce script. Au lieu de comptabiliser les samedis et les dimanches, le script comptabilise les vendredis et les samedis. En effet la fonction date() avec "w" comme paramètre de format renvoie le jour  au format numérique de  0 (pour dimanche) à 6 (pour samedi).

    Cordialment.

  • avatar

    Seanron

    13 Mai 2011 à 10:48

    petite correction concernant deux dates de la même année. code mis a jour.


 Autres snippets qui pourraient vous intéressez

Calcul le nombre de jours ouvrés entre 2 dates

Compatibilité : PHP 5, PHP 7

Fonction qui calcul et affiche le nombre de jours ouvrés entre 2 dates.

Calcul la différence de jour entre 2 dates

Compatibilité : PHP 5, PHP 7

Calcul la différence de jour entre 2 dates à partie de 2 dates passés en paramètre dans la fonction.

Calcul le nombre de jours écoulés depuis l'an zéro

Compatibilité : PHP 5, PHP 7

Cette fonction renvoie le facteur d'une date qui est le nombre de jours écoulés depuis le jour théorique de la naissance de J.C.

Afficher toute les dates entre 2 dates

Compatibilité : PHP 5, PHP 7

Avec la fonction mktime () et 1 boucle vous affichez ligne par ligne les dates comprises entre 2 dates prédéfinies à l'avance.

Nombre de jours dans 1 mois

Compatibilité : PHP 5, PHP 7

Fonction qui calcule le nombre de jours dans 1 mois, entre 1970 et 2037. (Sinon la fonction retourne 0).

Présentation de PHP

PHP débutant et initié 50 Tutoriel

Présentation de MySQL

avatar

Seanron

  12 Mai 2011

  SOURCE   Télécharger

Information sur les mises à jour

Dernière mise à jour :

    13 Aout 2019
    fonctionnement du code vérifié

8 297 Vues
Compatibilité
PHP 5, 7 et 8+
avatar
50 codes

Catégorie :  Dates - Heures

Addition de mois à une date
Affiche date et heure dynamiquement
Affiche la date dans une autre langue
Affiche la date de mise à jour d'1 page ou 1 script
Affiche la date du jour en Français
Affiche la date littérale en Français
Affiche le numéro de semaine ISO pour Windows
Affiche les dates du mois - Calendrier mensuel
Affiche les jours du mois
Affiche ligne par ligne les dates comprises entre 2 dates
Affiche une date avec le nom du jour et du mois
Ajoute ou soustrait des jours à une date
Calcul et affiche le lever et coucher du soleil
Calcul et trouve la date d'hier
Calcul l'age à partir de l'année
Calcul l'age à partir d'une date de naissance
Calcul la date de Paque à partir d'une année
Calcul la différence de jour entre 2 dates
Calcul la différence de temps du passé au présent
Calcul la différence entre 2 heures
Calcul le nombre de jours écoulés depuis l'an zéro
Calcul le nombre de jours non-ouvrés entre 2 dates
Calcul le nombre de jours ouvrés entre 2 dates
Calcul le temps restant ou le temps écoulé
Change de format de date us <=> fr
Classement de dates dans 1 fichier
Compte à  rebours du nouvel an
Compte le nombre de jour à partir d'une date
Convertie de secondes en heures, minutes et secondes
Convertie une date MySQL format US au format FR
Date du jour en français de manière littérale
Détermine rapidement si un jour est férié (fetes mobiles incluses)
Formulaire de date en HTML
Fractionne un créneau horaire entre l'heure de début et celle de fin
Indique si une année est bissextile ou pas
Injecte une Date SQL dans un tableau PHP
Lettres dominicales & Epacte julienne
Nombre de jours dans 1 mois
Obtient date + heure ( DATETIME ) au format littérale
Obtient la saison actuelle dans les 2 hémisphères
Quel sont les jours fériés en France
Retourne d'une date littérale la date exacte
Retourne le numéro de semaine passée en paramètre
Transforme une date dans un format littéraire et sympa
Trouve la date du prochain jour
Trouve les dates début et fin de semaine
Trouve si l'année est bissextile
Une autre utilisation de la fonction microtime ()
Vérifie la validité et l'existence d'une date
Vérifie si une date correspond au jour choisi