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

Collection et Stream Java Discussion :

Parser une date sans depasser jours et mois


Sujet :

Collection et Stream Java

  1. #1
    Membre régulier Avatar de zarohn
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    148
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 148
    Points : 94
    Points
    94
    Par défaut Parser une date sans depasser jours et mois
    Salut,

    J'ai une méthode qui valide une date (doit être au format jours.mois.année et doit être dans le passé), la voila :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    private boolean dateValide() {
            try {
                ParsePosition pos = new ParsePosition(0);
                DateFormat format = new SimpleDateFormat("dd.MM.yyyy" );
                Date date = format.parse(tfDate.getText(), pos);
                if (date.before(new Date()) && pos.getIndex() == tfDate.getText().length()) {
                    return(true);
                }
            } catch (Exception e) {}
            return(false);
        }
    Ça marche bien ! Seulement j'ai remarqué qu'on pouvait dépasser les jours et les mois.
    Par exemple si je fais un print de ma date parsée :

    Avec 31.12.2009 j'obtiens

    Sat Dec 31 00:00:00 CET 2009
    Ça c'est normal !

    Mais avec 32.12.2009 j'obtiens

    Fri Jan 01 00:00:00 CET 2010
    Avec 31.13.2009 j'obtiens

    Sun Jan 31 00:00:00 CET 2010
    Vous voyez ça a dépassé. Comment pourrais-je modifier ma méthode pour que ça ne parse que des dates valides ? En gros je voudrais qu'une date qui n'existe pas déclenche l'exception au lieu que ça parse en faisant le dépassement !

    Merci

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    faire appel à setLenient(true) sur le SimpelDateFormat pour le forcer à valider la date.

  3. #3
    Membre régulier Avatar de zarohn
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    148
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 148
    Points : 94
    Points
    94
    Par défaut
    Bonsoir tchize_, merci de vous intéresser à mon problème.
    J'ai ajouté l'instruction dont vous parlez :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
        private boolean dateValide() {
            try {
                ParsePosition pos = new ParsePosition(0);
                DateFormat format = new SimpleDateFormat("dd.MM.yyyy" );
                format.setLenient(true);
                Date date = format.parse(tfDate.getText(), pos);
                if (date.before(new Date()) && pos.getIndex() == tfDate.getText().length()) {
                    return(true);
                }
            } catch (Exception e) {}
            return(false);
        }
    Mais ça ne change absolument rien, ça se comporte de la même manière ...

  4. #4
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    pardon, c'est false, pas true

  5. #5
    Membre régulier Avatar de zarohn
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    148
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 148
    Points : 94
    Points
    94
    Par défaut
    Super ça marche, merci beaucoup pour l'aide

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

Discussions similaires

  1. [AC-2007] Forcer une date au premier jour du mois
    Par LouisT dans le forum Requêtes et SQL.
    Réponses: 27
    Dernier message: 01/03/2013, 18h16
  2. [Toutes versions] Copier une date sans inverser le jour et le mois
    Par peofofo dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 01/05/2009, 17h29
  3. Réponses: 4
    Dernier message: 25/04/2006, 19h41
  4. Réponses: 4
    Dernier message: 09/04/2006, 17h01
  5. Réponses: 9
    Dernier message: 30/11/2005, 18h18

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