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

Algorithmes et structures de données Discussion :

Calculer le nombre de jours restants


Sujet :

Algorithmes et structures de données

  1. #1
    Membre régulier

    Inscrit en
    Mai 2002
    Messages
    93
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 93
    Points : 85
    Points
    85
    Par défaut Calculer le nombre de jours restants
    Bonjour,
    Je rencontre un probléme d'imprécision lors d'affichage du nombre de jours restants, exemple :
    Je dois calculer le nombre de jours qui séparent deux dates diférentes, prenons la date1=2005-12-12 et date2=2006-01-12 (les valeurs sont en time stamp) j'aurais la difference :
    diff = date2 - date1
    diff est exprimé en secondes, le probléme c'est de savoir comment convertir diff en nombre de jours (facile), mois (comment gerer les mois à 31,30,29 et 28), an (365jours + ou -) ?
    Merci pour votre aide

  2. #2
    Membre averti Avatar de xxiemeciel
    Inscrit en
    Juin 2005
    Messages
    371
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 371
    Points : 352
    Points
    352
    Par défaut
    Tu peux faire une approximation de 30 jours pour un mois puisque dans le cas suivant :

    du 4 decembre 2005 au 18 janvier 2006 il y a 45 jours mais il n'existe aucun mois entre decembre et janvier. donc c'est environ 1 mois et 15 jours

    Ou sinon gere un calendrier complet c'est le seul moyen que je vois pour etre parfaitement exacte a tout les coup. et au lieu de faire une difference tu pars de ta date de depart dans ton calendrier et tu comptes jusqu'a la date d'arrivee. (sur 365.25 jours par an ca fera peu d'iteration donc c'est acceptable)

    XXiemeciel
    XXiemeciel

  3. #3
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Points : 4 297
    Points
    4 297
    Par défaut
    si tu n'as pas de librairie adaptée j'ai cette fonction ancienne
    en pascal préhistorique qui transforme un jour en nombre
    avec lequel on peut effectuer des calculs
    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
     
    FUNCTION FACTJOUR(J,M,A:INTEGER):longint;
    (*transforme une date en un nombre*)
    VAR FACT:REAL;
          BEGIN
    IF M IN[1,2] THEN
    BEGIN
    FACT:=(1.0*365*A)+1*J;
     FACT:=FACT+(1.0*(31*(M-1)));
     FACT:=FACT+(1.0*INT(((A-1)/4)));
    FACT:=FACT-(1.0*INT(3/4*INT(((A-1)/100)+1)));
       END
    ELSE
       BEGIN
    FACT:=(1.0*365*A)+J;
    FACT:=FACT+(1*(31*(M-1)));
    FACT:=FACT+(1.0*INT((A/4)));
    FACT:=FACT-INT(3/4*INT((A/100)+1));
    FACT:=FACT-INT(((0.4*M)+2.3));
       END;
    FACTJOUR:=round(FACT);
       END;
    Elle est pas belle la vie ?

Discussions similaires

  1. Calculer le nombre de jours restant suivant un évènement précis
    Par Olivier Regnier dans le forum Langage
    Réponses: 11
    Dernier message: 14/04/2008, 14h20
  2. Calculer le nombre de jours/heures/min/sec restant
    Par skaty dans le forum Requêtes
    Réponses: 5
    Dernier message: 20/11/2006, 17h47
  3. [Dates] Calculer le nombre de jours dans le mois suivant...
    Par Life Hunter dans le forum Langage
    Réponses: 5
    Dernier message: 14/03/2006, 00h01
  4. [Optimisation][Fonction]calcul du nombre de jours ...
    Par m-mas dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 26/10/2005, 14h39
  5. calcule du nombre de jours entre 2 dates
    Par nazimb dans le forum ASP
    Réponses: 4
    Dernier message: 28/09/2004, 15h22

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