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 :

Utilisation du bouton Annuler de inputbox comme sortie d'instruction pour une date [XL-2010]


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Homme Profil pro
    Inscrit en
    Avril 2008
    Messages
    87
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Avril 2008
    Messages : 87
    Points : 65
    Points
    65
    Par défaut Utilisation du bouton Annuler de inputbox comme sortie d'instruction pour une date
    Bonjour,

    Comment puis je me servir de ce bouton de l'inputbox comme une sortie d'intruction. j'ai vu différentes chose mais je n'ai pas réussi à sortir de l'instruction suite à une date.
    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
     
    Sub calculEFF2()
    'On Error GoTo fin:
    Dim Duree As Double, T As Double
     
    Dim wsPP As Worksheet, Activite As String, Nbrediag As Long, date_deb As Date
     
    Set wsPP = Sheets("Planning du personnel")
     
    With wsPP
    finlist = .Range("A1000").End(xlUp).Row
    fincol = .Range("XFD5").End(xlToLeft).Column
    debut:
    date_deb = InputBox("Quelle sera la date de début du calcul", "Date ?", Date)
    If date_deb = "00:00:00" Then Exit Sub
    ...
    Merci pour votre aide.
    Will

  2. #2
    Expert éminent sénior Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Points : 32 866
    Points
    32 866
    Par défaut
    Ton code ne peut pas marcher pour une raison très simple : InputBox ne renvoie que des String, il ne gère pas les dates.
    Peut-être qu'il peut convertir une valeur date en entrée comme valeur par défaut mais il renvoie un String.

    L'appui sur le bouton Annuler renvoie une chaîne vide.

    Mets un "Stop" entre ton InputBox et le If qui suit et regarde le contenu de la variable date_deb quand ce Stop est déclenché après un appui sur le Annuler du InputBox.
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  3. #3
    Membre chevronné
    Avatar de NVCfrm
    Homme Profil pro
    Administrateur Système/Réseaux - Developpeur - Consultant
    Inscrit en
    Décembre 2012
    Messages
    1 036
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations professionnelles :
    Activité : Administrateur Système/Réseaux - Developpeur - Consultant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 036
    Points : 1 917
    Points
    1 917
    Billets dans le blog
    5
    Par défaut
    Citation Envoyé par Menhir Voir le message
    Ton code ne peut pas marcher pour une raison très simple : InputBox ne renvoie que des String, il ne gère pas les dates.
    Peut-être qu'il peut convertir une valeur date en entrée comme valeur par défaut mais il renvoie un String.
    La conversion est toujours implicite. Il suffit que le texte corresponde au format attendu par la variable.
    InputBox reconnaît le type d'une donnée entrée et le renvoi. Long, Date, Double, String...
    Beaucoup préférent de recueillir ce renvoi dans un String parce qu'on ne peut faire confiance à ce que l'utilisateur va rentrer, pour évier une incompatibilité de type.
    Mon avis est qu'il vaut mieux typer la variable dans le type attendu pour ne pas continuer avec une saisie incorrecte.
    Ousmane


    Quand on tombe dans l'eau, la pluie ne fait plus peur.

  4. #4
    Membre émérite
    Inscrit en
    Octobre 2010
    Messages
    1 401
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 1 401
    Points : 2 684
    Points
    2 684
    Par défaut
    Bonjour.

    Pour illustrer les explications de Menhir et de NVCfrm :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Dim reponse As String
    reponse = InputBox("Date ?", "Quelle sera la date de début du calcul", Date)
    If reponse = "" Then
     Exit Sub
    ElseIf Not IsDate(reponse) Then 'On doit vérifier que la valeur retournée par InputBox est une date valide pour ne pas que date_deb = reponse provoque une erreur car date_deb qui est de type DATE
     MsgBox reponse & " n'est pas un format de date reconnu. "
     Exit Sub
    Else
      date_deb = reponse ' La date de type STRING qui est dans reponse est convertie en date de type DATE lorsque attribuée à la variable date_deb.
    End If
    Cordialement

    Docmarti.

  5. #5
    Membre du Club
    Homme Profil pro
    Inscrit en
    Avril 2008
    Messages
    87
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Avril 2008
    Messages : 87
    Points : 65
    Points
    65
    Par défaut
    Merci à vous ça fonctionne :-)

    Et Docmarti encore plus à toi pour avoir mis en code ce que disait Menhir.

    Bonne journée à vous,
    Will

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 28/09/2014, 08h47
  2. le bouton annuler sur inputbox
    Par kroma23 dans le forum Débuter
    Réponses: 8
    Dernier message: 26/04/2013, 11h13
  3. Réponses: 7
    Dernier message: 27/11/2012, 23h59
  4. Réponses: 7
    Dernier message: 18/11/2008, 14h50
  5. Maitriser le bouton annuler de InputBox
    Par Bubale dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 06/05/2008, 13h36

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