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 :

Différences entre deux TDateTime ?


Sujet :

Langage Delphi

  1. #1
    Membre averti
    Homme Profil pro
    Paramétreur de progiciels
    Inscrit en
    Octobre 2006
    Messages
    970
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Paramétreur de progiciels

    Informations forums :
    Inscription : Octobre 2006
    Messages : 970
    Points : 381
    Points
    381
    Par défaut Différences entre deux TDateTime ?
    Bonjour,

    J'utilise quatre TDateTimePicker qui marchent par couple Date et Time.

    Je cherche donc à encoder ces deux couples en TDateTime puis à en faire la différence pour l'afficher en jour(s), heure(s) et minute(s).

    Voici mon bout de code actuel :
    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
     
    procedure TForm1.Button1Click(Sender: TObject);
    var
         Debut     : TDateTime;
         Fin       : TDateTime;
         Duree     : TDateTime;
         J,Mo,A    : Word;
         H,Mi,S,MS : Word;
    begin
         Debut := DateTimePicker1.Date + DateTimePicker2.Time;
         Fin := DateTimePicker3.Date + DateTimePicker4.Time;
         Duree := Fin - Debut;
         DecodeDate(Duree,A,Mo,J);
         DecodeTime(Duree,H,Mi,S,MS);
         Edit1.Text := IntToStr(J) + ' - ' + IntToStr(Mo) + ' - ' + IntToStr(A) + ' - ' + IntToStr(H) + 'h' + IntToStr(Mi);
    end;
     
    procedure TForm1.Button2Click(Sender: TObject);
    begin
         DateTimePicker3.Date := Date;
         DateTimePicker4.Time := Time;
    end;
     
    procedure TForm1.Button3Click(Sender: TObject);
    begin
         DateTimePicker1.Date := Date;
         DateTimePicker2.Time := Time;
    end;
    Mon code ne semble pas donner les résultats attendus

    Merci pour votre aide,
    ZiP

  2. #2
    Membre chevronné

    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    1 519
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 1 519
    Points : 2 153
    Points
    2 153
    Billets dans le blog
    1
    Par défaut
    Essaye ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Debut := Trunc( DateTimePicker1.Date ) + Frac( DateTimePicker2.Time );
    Fin := Trunc( DateTimePicker3.Date ) + Frac( DateTimePicker4.Time );
    Explication dans un DateTime, la date est encodée dans la partie entière du nombre réel et l'heure dans la partie décimale (donc après la virgule).

  3. #3
    rsc
    rsc est déconnecté
    Membre éprouvé
    Avatar de rsc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juin 2004
    Messages
    711
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2004
    Messages : 711
    Points : 918
    Points
    918
    Par défaut
    Pour le nombre de jours ça ne peut pas marcher : DecodeDate te renvoie le quantième de la date représentée par ton nombre, étant entendu que 0 correspond au 30/12/1899 !
    J'utiliserais un calcul du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    J := Trunc (Duree);
    H := Trunc ((Duree - J) * 24);
    MN := Trunc (((Duree - J) * 24 - H) * 60);

  4. #4
    Membre averti
    Homme Profil pro
    Paramétreur de progiciels
    Inscrit en
    Octobre 2006
    Messages
    970
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Paramétreur de progiciels

    Informations forums :
    Inscription : Octobre 2006
    Messages : 970
    Points : 381
    Points
    381
    Par défaut
    Salut,

    Avec vos deux réponses mixées, tout marche parfaitement !

    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
     
    procedure TForm1.Button1Click(Sender: TObject);
    var
         Debut     : TDateTime;
         Fin       : TDateTime;
         Duree     : TDateTime;
         J,H,M     : Word;
    begin
         Debut := Trunc(DateTimePicker1.Date) + Frac(DateTimePicker2.Time);
         Fin := Trunc(DateTimePicker3.Date) + Frac(DateTimePicker4.Time);
         Duree := Fin - Debut;
         J := Trunc(Duree);
         H := Trunc((Duree-J)*24);
         M := Trunc(((Duree-J)*24-H)*60);
         Edit1.Text := IntToStr(J) + ' jour(s) - ' + IntToStr(H) + 'h' + IntToStr(M);
    end;
    Merci,
    ZiP

  5. #5
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Ne serait il pas mieux d'utiliser MinutesBetween qui se trouve dans l'unité DateUtils puis de faire le calcul d'affichage après ?

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 14/04/2011, 15h23
  2. [access] différence entre deux champs
    Par loutente dans le forum Langage SQL
    Réponses: 1
    Dernier message: 17/08/2005, 15h57
  3. Différence entre deux dates
    Par pittzz dans le forum Oracle
    Réponses: 5
    Dernier message: 18/07/2005, 12h24
  4. Comment obtenir la différence entre deux dates ?
    Par jbat dans le forum Langage
    Réponses: 4
    Dernier message: 02/06/2005, 09h34
  5. Résultats erroné différence entre deux types TDateTime
    Par Alghero dans le forum C++Builder
    Réponses: 6
    Dernier message: 12/03/2004, 17h03

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