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

iReport Discussion :

Calcul Temps écoulé entre 2 dates


Sujet :

iReport

  1. #1
    Membre à l'essai
    Inscrit en
    Mars 2009
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 22
    Points : 13
    Points
    13
    Par défaut Calcul Temps écoulé entre 2 dates
    Bonjour,
    Comment calculer le temps écoulé entre :
    date_mod = 2009-06-19 16:32:45
    date_cre = 2009-06-19 11:12:00

    j'ai créé une variable 'result' avec le type java.lang.integer et saisi la formule suivante dans l'expression :
    new Integer( (int) ( ($F{date_mod}.getTime() - $F{date_cre}.getTime()) / (1000*60*60*24) ))

    le résultat est à 0 alors que l'écart devrait être égal à 0 jour 05h 20mn 45s
    Pouvez-vous me donner la syntaxe exacte de la formule
    Merci pour votre aide
    Cordialement

  2. #2
    Membre éprouvé

    Inscrit en
    Janvier 2009
    Messages
    467
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 467
    Points : 1 253
    Points
    1 253
    Billets dans le blog
    2
    Par défaut
    Je n'est pas encore bien compris comment le mélange Java jrxml fonctionne...

    Mais en JAVA pour comparer deux dates, il y a la fonction : compareTo(java.util.Date) de java.util.Date

    Autrement dit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $F{date_mod}.compareTo($F{date_cre})
    + le formatage... (car compareTo retourne un entier relatif).
    et peut être en laissant l'instanciation de Integer (new Interger( ...) )


    A et enfin (j'y pense en relisant ta ligne de code) :
    il se peut que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ( ($F{date_mod}.getTime() - $F{date_cre}.getTime()) / (1000*60*60*24) )
    soit un nombre décimal et que ce soit ton "cast" avec "(int)" qui retourne 0...

    Est ce que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    new Integer( (int) ($F{date_mod}.getTime() - $F{date_cre}.getTime()) )
    donne quelque chose ??? et sans le cast ???

  3. #3
    Membre à l'essai
    Inscrit en
    Mars 2009
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 22
    Points : 13
    Points
    13
    Par défaut
    Je viens de tester avec 'compare to' mais le type pose un problème que je mette java.lang.integer ou java.util.date ou java.sql.timestamp ou java.sql.time
    j'ai toujours le message d'erreur Cannot cast from.... to .....

    Les 2 autres solutions que vous proposez m'affiche le même genre d'erreur
    Je n'arrive pas à trouver le type à assigner à la variable créée

    j'espère que mes commentaires ne sont pas trop nébuleux....
    Cordialement

  4. #4
    Membre à l'essai
    Inscrit en
    Mars 2009
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 22
    Points : 13
    Points
    13
    Par défaut
    En changeant le type de new Integer par new Double, la résultat de la formule est correct .
    Merci pour votre aide
    Cordialement

  5. #5
    Nouveau Candidat au Club
    Homme Profil pro
    Paramétreur de progiciels
    Inscrit en
    Décembre 2017
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Paramétreur de progiciels

    Informations forums :
    Inscription : Décembre 2017
    Messages : 1
    Points : 1
    Points
    1
    Par défaut A l'aide
    Bonjour à tous,

    Je rencontre le même problème.
    Je souhaite soustraire deux dates dans mon rapport. J'ai créé une variable $F{EXPEDITION_EXPEDITION_DATE}.compareTo( $F{CLIENT_REQUEST_DATE} ) dans le champ "variable expression" de ma variable.
    J'obtiens bien le résultat pour des calculs simple (15-12=2) par contre lorsqu'il faut changer de dizaine (21-18=1) j'ai des valeurs erronées.
    Je pense qu'il faut juste un petit réglage mais je ne trouve pas la subtilité.

    Si quelqu'un à une piste je suis preneur.

    A bientôt

    Grandcitron

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

Discussions similaires

  1. Calculer le temps écoulé entre deux dates
    Par ramoucha23 dans le forum Collection et Stream
    Réponses: 8
    Dernier message: 25/08/2016, 17h48
  2. [XL-2007] Calculer le temps écoulé entre 2 dates
    Par marie-dominique dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 20/01/2012, 17h37
  3. Temps écoulé entre 2 dates et 2 horaires
    Par christ-94 dans le forum VBA Access
    Réponses: 8
    Dernier message: 25/01/2009, 17h53
  4. Calcul temps ecoulé entre deux dates
    Par biazoc dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 17/05/2008, 15h21
  5. Temps écoulé entre 2 dates
    Par casafa dans le forum Algorithmes et structures de données
    Réponses: 9
    Dernier message: 23/12/2005, 03h04

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