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

VB 6 et antérieur Discussion :

problème comparaison de date VB


Sujet :

VB 6 et antérieur

  1. #1
    Membre du Club
    Inscrit en
    Mars 2005
    Messages
    40
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 40
    Points : 40
    Points
    40
    Par défaut problème comparaison de date VB
    voila je récupère la date d expiration de mon compte
    avec la fonction suivante

    Set usr = GetObject(cheminNT)
    cptEtat = usr.AccountExpirationDate
    et je voudrais la comparer a la date du jour

    avec un if cptetat >= DAte then msgbox "compte actif".........

    le problème c est que cptetat
    est de la forme "10/09/2005"
    et date c est juste 10/10/2005 sans quote

    et quelquesoit la date il me répond compte actif comme si il n arrivait pas a comparer a cause des quotes

    quelqun aurait il une solution pour faire la comparaison

    par avance merci

  2. #2
    Membre expérimenté Avatar de Megaxel
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    1 187
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 1 187
    Points : 1 405
    Points
    1 405
    Par défaut
    Si tu essaies de mettre un CDate( ) de ton cptetat, ça donne quoi?
    Sans conviction... Mais bon, peut-être...

  3. #3
    Membre du Club
    Inscrit en
    Mars 2005
    Messages
    40
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 40
    Points : 40
    Points
    40
    Par défaut
    le probleme c est qu il fait pas vraiment la comparaison de date je pense
    Cdate correspond a ceci?

  4. #4
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    Les dates sont à encadrer avec # et à passer au format US mm/ddd/yyyy

    Soit aujourd'hui

    #10/18/2005#

  5. #5
    Membre éclairé
    Avatar de Theocourant
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    618
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 618
    Points : 739
    Points
    739
    Par défaut
    Salut,

    Une solution aussi pour récupérer la date du jour est d'utiliser la fonction "Now" et "DateDiff" pour voir s'il existe une différence de date

    Théo
    Forums VB : lire la notice
    La touche existe pour être utilisée
    Pensez au tag
    Pour ceux n'ayant pas l'aide installée :
    - Aide MSDN pour VB6
    - Aide MSDN pour VBA
    Je ne réponds pas aux questions techniques par MP. Merci d'utiliser le forum fait pour çà.

  6. #6
    Membre du Club
    Inscrit en
    Mars 2005
    Messages
    40
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 40
    Points : 40
    Points
    40
    Par défaut
    je pense que cdate pour convertir est la meilleure idée

    car c est peut etre considerer comme un string et c est ca qui gene
    je vais tester

    merci

  7. #7
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    le probleme c est qu il fait pas vraiment la comparaison de date je pense
    Cdate correspond a ceci?
    S'il s'agit de récupérer la date 10/10/2005 pour avoir "10/10/2005", cdate ne marche pas.
    Tofalu te dit d'encadrer ta date : #10/18/2005# mais je ne vois pas comment tu peux faire. C'est cependant ce que j'ai aussi trouvé dans l'aide.

    A+

  8. #8
    Membre éprouvé
    Avatar de méphistopheles
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 551
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 551
    Points : 1 220
    Points
    1 220
    Par défaut
    une petite idée:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cptetat="#" & cptetat & "#"
    salut
    Méphistophélès
    Si la solution ne résout pas votre problème, changez le problème...
    Cours et tutoriels C++ - FAQ C++ - Forum C++.

  9. #9
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Dans ton exemple, tu assimiles cptetat à un string... "Ça..." pas marcher chez moi...

    A+

  10. #10
    Expert confirmé
    Avatar de zazaraignée
    Profil pro
    Étudiant
    Inscrit en
    Février 2004
    Messages
    3 174
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2004
    Messages : 3 174
    Points : 4 085
    Points
    4 085
    Par défaut
    Salut

    Moi, ce que j'aimerais savoir c'est si cptetat provient d'un état ou s'il vient directement de la base de données (Table ou Requête).

    Je soupçonne l'état de retourner une string alors que la BD retournera un format de date. Ce n'est qu'une supposition. Comme je l'ai déjà dit je ne suis pas vraiment familère avec la communication avec les BD en VB (c'est pour le prochain trimestre).

    J'espère en tout cas que mon intervension pourra vous mettre sur une piste valable.

  11. #11
    Membre éprouvé
    Avatar de méphistopheles
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 551
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 551
    Points : 1 220
    Points
    1 220
    Par défaut
    si j'ai bien compris, ton problème est de retirer les guillemets dans cptEtat qui sont à gauche et à droite? pour cela, il existe une fonction simple:

    avant ton code, met:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cptEtat=replace(replace(cptetat,left(cptetat,1),"",1,1),right(cptetat,1),"",str(cpetat)-2,1)
    Normalement, ça marche
    salut
    Méphistophélès
    Si la solution ne résout pas votre problème, changez le problème...
    Cours et tutoriels C++ - FAQ C++ - Forum C++.

  12. #12
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    si j'ai bien compris, ton problème est de retirer les guillemets dans cptEtat qui sont à gauche et à droite
    Non, méphistons, ce serait plutôt de mettre des parenthèses à gauche et à droite de 10/10/2005...
    bref, de convertir 10/10/2005 en string... Mais je crois que zaza a posé la bonne question (?)

    A+

  13. #13
    Membre du Club
    Inscrit en
    Mars 2005
    Messages
    40
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 40
    Points : 40
    Points
    40
    Par défaut
    bon au final

    j ai fait cela pour formater en date puis en version uk comme l indiquait tofalu

    cptEtat = usr.AccountExpirationDate
    cptdate = CDate(cptEtat)
    mydate = CDate(Datedujour)
    UK1 = Format(cptdate, "mm/dd/yy")
    UK2 = Format(mydate, "mm/dd/yy")

    If UK1 >= UK2 Then


    merci poru votre aide je le met en solve

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

Discussions similaires

  1. problème comparaison de date
    Par maysa dans le forum Macro
    Réponses: 10
    Dernier message: 20/04/2011, 13h44
  2. Problème comparaison de date
    Par stmastma dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 25/02/2010, 10h48
  3. Problème comparaison de date sur 4 caractères
    Par carmella dans le forum SQL
    Réponses: 4
    Dernier message: 11/02/2009, 10h44
  4. [Dates] Problème comparaison de dates
    Par Davboc dans le forum Langage
    Réponses: 2
    Dernier message: 23/08/2006, 12h23
  5. Problème de comparaison de dates
    Par MiJack dans le forum Langage SQL
    Réponses: 2
    Dernier message: 12/03/2004, 21h43

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