IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

Comment calculer le nombre de jours entre deux dates


Sujet :

Langage PHP

  1. #1
    Débutant  
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 096
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 096
    Points : 944
    Points
    944
    Par défaut Comment calculer le nombre de jours entre deux dates
    Bonjour,

    Je cherche en vain une solution pour calculer le nombres de jour entre deux dates.
    mais il faudrait qu0il ne tienne pas compte des week-end et des jours fériées paramétré.

    Comment puis-je.
    1) Définir les jour fériées
    2) Et accessoirement les jour fériées?

    Milles mercis pour votre aide
    Il ne suffit pas de tout savoir. Vouloir et persévérer, c'est déjà presque tout!

  2. #2
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour,

    date_diff
    Pour les jours fériés, je ne sais pas si c'est possible.

    A+.

  3. #3
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 691
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 691
    Points : 20 222
    Points
    20 222
    Par défaut
    Les jours fériés se calculent assez facilement :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    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
     
    class Date_Ferie
    {
     
        private $tabDay = array();
     
        private $annee;
     
        public function __construct($annee)
        {
            $this->annee    = $annee;
            $this->tabDay[] = $annee . '-01-01';
            $this->tabDay[] = ($annee + 1) . '-01-01';
            $this->tabDay[] = ($annee - 1) . '-01-01';
            $this->tabDay[] = $annee . '-05-01';
            $this->tabDay[] = $annee . '-05-08';
            $this->tabDay[] = $annee . '-07-14';
            $this->tabDay[] = $annee . '-08-15';
            $this->tabDay[] = $annee . '-11-01';
            $this->tabDay[] = $annee . '-11-11';
            $this->tabDay[] = $annee . '-12-25';
            $this->computeDay();
        }
     
        private function computeDay()
        {
            //Paques
            $tsPaques = @easter_date($this->annee);
            $this->tabDay[] = date("Y-m-d", $tsPaques + 86400);
            //Ascencion
            $this->tabDay[] = date("Y-m-d", strtotime('+39 days', $tsPaques));
            //Pantecote
            $this->tabDay[] = date("Y-m-d", strtotime('+50 days', $tsPaques));
        }
     
    	//Format de la date Y-m-d
        public function isFerie($date)
        {        
    		return in_array($date, $this->tabDay);
        }
     
    }
     
    $date= new Date_Ferie(2011);
    $date->isFerie('2011-12-25'); // true
    Ce petit bout de code permet de vérifier si une date au format Y-m-d est une date fériée ou non (selon les jour férié français).

    Il te suffit donc de simplement vérifier si les dates dans ton interval sont fériées ou non puis de soustraire le nombre de jours fériés au résultat du nombre de jour entre tes deux dates.

    Note : Le code présenté est plus fait pour vérifier une date en particulier , si tu as beaucoup de date , il serait judicieux de l'adapter pour être plus performant.
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  4. #4
    Modérateur
    Avatar de Bisûnûrs
    Profil pro
    Développeur Web
    Inscrit en
    Janvier 2004
    Messages
    9 868
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2004
    Messages : 9 868
    Points : 16 258
    Points
    16 258
    Par défaut
    Citation Envoyé par grunk Voir le message
    (selon les jour férié français)
    Ca dépend où l'on se trouve en France. En Alsace/Moselle, il y a deux jours fériés en plus : Le vendredi saint et le 26 décembre.

  5. #5
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 691
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 691
    Points : 20 222
    Points
    20 222
    Par défaut
    Citation Envoyé par Bisûnûrs Voir le message
    Ca dépend où l'on se trouve en France. En Alsace/Moselle, il y a deux jours fériés en plus : Le vendredi saint et le 26 décembre.
    L'Alsace/Lorraine serait redevenu française ?
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  6. #6
    Membre expérimenté

    Profil pro
    Inscrit en
    Août 2002
    Messages
    1 060
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 1 060
    Points : 1 357
    Points
    1 357
    Par défaut
    Bonjour,

    grunk => Juste une petite remarque : le décalage de la Pentecôte est de 49 jours et non pas 50.

    A titre d'information, quelle est l'utilité de prendre le 1er janvier de l'année -1 et de l'année +1 ?

  7. #7
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 691
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 691
    Points : 20 222
    Points
    20 222
    Par défaut
    Citation Envoyé par jeca Voir le message
    Bonjour,

    grunk => Juste une petite remarque : le décalage de la Pentecôte est de 49 jours et non pas 50.

    A titre d'information, quelle est l'utilité de prendre le 1er janvier de l'année -1 et de l'année +1 ?
    Dans le code la pentecote est à +50 car c'est le lundi qui est férié alors que easter_day retourne le dimanche tout comme la pantecote qui est un dimanche.

    Pour le premier janvier , j'ai bien envie de te dire que j'en sais rien ^^ . Ca à sans doute une raison historique au projet pour lequel je l'avait fait , mais me souviens plus pourquoi
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  8. #8
    Membre expérimenté

    Profil pro
    Inscrit en
    Août 2002
    Messages
    1 060
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 1 060
    Points : 1 357
    Points
    1 357
    Par défaut
    Bonjour,

    Citation Envoyé par grunk Voir le message
    Dans le code la pentecote est à +50 car c'est le lundi qui est férié alors que easter_day retourne le dimanche tout comme la pantecote qui est un dimanche.
    Sans chercher à déclencher une polémique, je trouve "choquant" que la classe retourne "non férié" si je teste la date de Pâques ou de la Pentecôte.
    Cela dit, si ça ne me conviens pas, il faut 30 secondes pour ajouter ces 2 jours...

    @+

  9. #9
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 691
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 691
    Points : 20 222
    Points
    20 222
    Par défaut
    Sans chercher à déclencher une polémique, je trouve "choquant" que la classe retourne "non férié" si je teste la date de Pâques ou de la Pentecôte.
    Comme je l'ai dit la classe avait pour but d'afficher les jours non travaillés sur un calendrier. Les dimanches étant forcément chômés (dans mon cas) c'est les lundi qui m'intéressait

    Après ce n'est qu'une proposition et comme tu le précises il est très simple de réadapter si on veux les dates exactes
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

Discussions similaires

  1. [TPW] Calcul du nombre de jours entre deux dates
    Par forum dans le forum Codes sources à télécharger
    Réponses: 2
    Dernier message: 03/04/2017, 19h24
  2. Calculer le nombre de jours entre deux dates
    Par titoumimi dans le forum Contribuez / Téléchargez Sources et Outils
    Réponses: 0
    Dernier message: 14/02/2011, 19h07
  3. [VxiR2] Calcul du nombre de jours entre deux dates
    Par PATRICIA02 dans le forum Webi
    Réponses: 4
    Dernier message: 23/07/2009, 12h43
  4. calcule du nombre de jours entre deux date
    Par chalcol dans le forum Oracle
    Réponses: 3
    Dernier message: 23/03/2009, 16h36
  5. Réponses: 2
    Dernier message: 29/05/2006, 19h16

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo