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 Delphi Discussion :

calcul nombre de jours entre deux dates


Sujet :

Langage Delphi

  1. #1
    Membre du Club Avatar de charlene44
    Profil pro
    Étudiant
    Inscrit en
    Juin 2006
    Messages
    87
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2006
    Messages : 87
    Points : 67
    Points
    67
    Par défaut calcul nombre de jours entre deux dates
    bonjour,

    j'ai un petit problème : j'ai des dates stockées dans ma base de données au format date, et avec deux dates j'aimerai trouver le nombre de jours qui les séparent, donc obtenir un entier, comment est-ce que je pourrai faire pour calculer ca? merci d'avance

  2. #2
    Membre habitué
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Santé

    Informations forums :
    Inscription : Mai 2002
    Messages : 245
    Points : 154
    Points
    154
    Par défaut
    Salut,

    Tu peux utiliser la fonction DaysBetween. Ca te donne le nombre de jours entiers entre deux TDateTime.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    function DaysBetween(const ANow, AThen: TDateTime): Integer;

  3. #3
    Membre expert
    Avatar de e-ric
    Homme Profil pro
    Apprenti chat, bienfaiteur de tritons et autres bestioles
    Inscrit en
    Mars 2002
    Messages
    1 552
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Apprenti chat, bienfaiteur de tritons et autres bestioles

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 552
    Points : 3 918
    Points
    3 918
    Par défaut
    La réponse précédente est valable si tu manipules les dates dans le code Delphi sous forme de TDateTime à partir de Delphi 6 sinon

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    function DaysBetween(const ANow, AThen: TDateTime): Integer;
    begin
      Result := Abs(Trunc(AThen) - Trunc(ANow));
    end;
    est une implémentation envisageable.

    Ce type est en fait un réel qui prend en valeur entière le nombre de jours écoulé depuis une date de référence (je ne me souviens pas la valeur) et en valeur fractionnaire l'heure.
    Pour obtenir un nombre de jour, il suffit donc de faire la différence entre les deux dates à 00h00.

    cdlt

    M E N S . A G I T A T . M O L E M
    Debian 64bit, Lazarus + FPC -> n'oubliez pas de consulter les FAQ Delphi et Pascal ainsi que les cours et tutoriels Delphi et Pascal

    "La théorie, c'est quand on sait tout, mais que rien ne marche. La pratique, c'est quand tout marche, mais qu'on ne sait pas pourquoi. En informatique, la théorie et la pratique sont réunies: rien ne marche et on ne sait pas pourquoi!".
    Mais Emmanuel Kant disait aussi : "La théorie sans la pratique est inutile, la pratique sans la théorie est aveugle."

  4. #4
    Membre du Club Avatar de charlene44
    Profil pro
    Étudiant
    Inscrit en
    Juin 2006
    Messages
    87
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2006
    Messages : 87
    Points : 67
    Points
    67
    Par défaut
    merci beaucoup, je vais essayer ca!

  5. #5
    Membre émérite Avatar de edam
    Homme Profil pro
    Développeur Delphi/c++/Omnis
    Inscrit en
    Décembre 2003
    Messages
    1 894
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur Delphi/c++/Omnis
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 894
    Points : 2 771
    Points
    2 771
    Par défaut
    Citation Envoyé par e-ric
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    function DaysBetween(const ANow, AThen: TDateTime): Integer;
    begin
      Result := Abs(Trunc(AThen) - Trunc(ANow));
    end;
    est une implémentation envisageable.
    mais noublie que ce code va donnée une journé de moins
    PAS DE DESTIN, C'EST CE QUE NOUS FAISONS

  6. #6
    Membre du Club Avatar de charlene44
    Profil pro
    Étudiant
    Inscrit en
    Juin 2006
    Messages
    87
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2006
    Messages : 87
    Points : 67
    Points
    67
    Par défaut
    ba ca marche en tout cas, merci beaucoup, ca donne ca, j'ai fait un exemple super rapidement pour tester, c'est pas du tout optimisé mais bon c'est pas grave ca donne : ca

  7. #7
    Membre émérite Avatar de edam
    Homme Profil pro
    Développeur Delphi/c++/Omnis
    Inscrit en
    Décembre 2003
    Messages
    1 894
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur Delphi/c++/Omnis
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 894
    Points : 2 771
    Points
    2 771
    Par défaut
    au contraire ce code donnée par eric que je préfér, et meme quelque fois je change tt les date et les heur en integer pour facilité le calcul
    PAS DE DESTIN, C'EST CE QUE NOUS FAISONS

  8. #8
    Futur Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    6
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 6
    Points : 7
    Points
    7
    Par défaut Différence entre deux dates
    L'exemple est fait avec deux composants TDatetimePicker qui envoient leurs valeurs vers les variables p1 et p2. Juste un ajout sur ce qui existe déjà.

    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
    procedure TForm1.Button1Click(Sender: TObject);
    var D1,D2,p1,p2:TDateTime;
        Year, Month, Day: Word;
        Year1, Month1, Day1: Word;
        Diff:Integer;
    begin
      P1:=DateDeb.Date;
      p2:=DateFin.Date;
      DecodeDate(P1, Year, Month, Day);
      DecodeDate(P2, Year1, Month1, Day1);
      D1:=EncodeDate(Year,Month,Day);
      D2:=EncodeDate(Year1,Month1,Day1);
      Diff:=TRUNC(D2-D1);
      Label1.Caption:=IntToStr(Diff);
    end;

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Calculer nombre de jours entre deux dates
    Par faty_br dans le forum Collection et Stream
    Réponses: 11
    Dernier message: 11/03/2013, 16h15
  2. Comment calculer le nombre de jours entre deux dates
    Par pierrot10 dans le forum Langage
    Réponses: 8
    Dernier message: 22/06/2011, 08h38
  3. 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
  4. [VxiR2] Calcul du nombre de jours entre deux dates
    Par PATRICIA02 dans le forum Webi
    Réponses: 4
    Dernier message: 23/07/2009, 12h43
  5. calcule du nombre de jours entre deux date
    Par chalcol dans le forum Oracle
    Réponses: 3
    Dernier message: 23/03/2009, 16h36

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