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

Macros et VBA Excel Discussion :

Comparer deux dates [XL-2003]


Sujet :

Macros et VBA Excel

  1. #1
    Membre éclairé Avatar de PtitGénie
    Homme Profil pro
    Développeur Web
    Inscrit en
    Décembre 2007
    Messages
    231
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Décembre 2007
    Messages : 231
    Par défaut Comparer deux dates
    Bonjour à tous !

    Mon problème est simple mais me prend la tête depuis quelques heures :
    J'ai cette condition :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    MsgBox Format(ActiveCell.Offset(0, 2).Value, "dd/mm/yyyy")
    MsgBox Format(Evaluate("DATE(YEAR(TODAY()),MONTH(TODAY()) ,0)+1"), "dd/mm/yyyy")
    If Format(ActiveCell.Offset(0, 2).Value, "dd/mm/yyyy") < Format(Evaluate("DATE(YEAR(TODAY()),MONTH(TODAY()) ,0)+1"), "dd/mm/yyyy") Then
                MsgBox "La date de la cellule est inférieure au début du mois en cours."
    Mon "ActiveCell.Offset(0, 2).Value" contient "01/03/2012" (confirmé par la MsgBox), et idem j'ai bien la date de début de ce mois avec la MsgBox (01/05/2011).
    Or il rentre dans ma condition et m'affiche le MsgBox "La date de début blabla...", pourtant 01/03/2012 n'est pas inférieur à 01/05/2011 !

    Merci d'avance...

  2. #2
    Membre Expert
    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    673
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2007
    Messages : 673
    Par défaut
    Bonjour,
    C'est normal, le test
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If Format(ActiveCell.Offset(0, 2).Value, "dd/mm/yyyy") < Format(Evaluate("DATE(YEAR(TODAY()),MONTH(TODAY()) ,0)+1"), "dd/mm/yyyy") Then
    ne compare pas les dates mais les chaînes de caractères, et "01/03/2012" est bien inférieure à "01/05/2011".

    Pour comparer vraiment les dates, il faut utiliser la syntaxe suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If ActiveCell.Offset(0, 2).Value < DateSerial(YEAR(Now), MONTH(Now), 1) Then

  3. #3
    pgz
    pgz est déconnecté
    Expert confirmé Avatar de pgz
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Août 2005
    Messages
    3 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Office VBA
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Par défaut
    Bonjour.

    Je suis d'accord avec tedo01.
    Si tu tiens à utiliser Format, il faut choisir "yyyy/mm/dd", format ISO.

    PGZ

  4. #4
    Membre éclairé Avatar de PtitGénie
    Homme Profil pro
    Développeur Web
    Inscrit en
    Décembre 2007
    Messages
    231
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Décembre 2007
    Messages : 231
    Par défaut
    Merci beaucoup c'est nickel !

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

Discussions similaires

  1. Comment comparer deux dates
    Par vodevil dans le forum Modules
    Réponses: 6
    Dernier message: 01/09/2005, 18h24
  2. comparer deux dates
    Par adel25 dans le forum C++
    Réponses: 3
    Dernier message: 23/08/2005, 20h29
  3. Comparer deux dates
    Par LoicH dans le forum C++Builder
    Réponses: 4
    Dernier message: 04/03/2005, 22h53
  4. comment comparer deux dates?
    Par billoum dans le forum C++Builder
    Réponses: 2
    Dernier message: 21/08/2004, 21h08

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