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 :

Commande inputbox


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de neoboy
    Inscrit en
    Juillet 2007
    Messages
    200
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 200
    Par défaut Commande inputbox
    Hello ,


    J'ai un petit souci avec la commande inputbox !

    1 / Je veux connaitre la différence entre application.inputbox et inputbox seule !

    2 / J'ai une qui permet de réccuperer des données via un inputbox ,mais le problème qui se pose c'est quan j'appuie sur annuler il sort pas !!


    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
    17
    18
    19
    20
    21
     For i = 1 To n
     
            j = Application.InputBox("Entrer la durée opératoire de la pièce" & "  " & i, "Durée opératoire pièce")
     
            If Not IsNumeric(j) Or j < 0 Then
     
                MsgBox "La durée opératoire doit être une valeur numérique positive", vbCritical, "Erreur saisie"
                i = i - 1
     
            ElseIf j - Int(j) <> 0 Then
     
                MsgBox "La durée opératoire doit un entier", vbCritical, "Erreur saisie"
                i = i - 1
     
            Else
     
            p(i) = j
     
            End If
     
        Next i

    merci d'avance de votre aide !!

  2. #2
    Inactif  
    Profil pro
    Inscrit en
    Février 2010
    Messages
    517
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 517
    Par défaut
    Salut,

    Je te suggère d'aller au plus simple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    For i = 1 To 3
       j = Application.InputBox("Entrer la durée opératoire de la pièce (entier positif uniquement) ou Annuler pour abandonner" & "  " & i, "Durée opératoire pièce")
       If j = False Then Exit For
       If Not j Like String(Len(j), "#") Then
           MsgBox "seul un entier positifr est attendu !"
       Else
           p(i) = j
        End If
     Next i

  3. #3
    Membre confirmé Avatar de neoboy
    Inscrit en
    Juillet 2007
    Messages
    200
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 200
    Par défaut
    merci beaucoup pour la simplification !!!

    Hello,

    Juste un souci au niveau du code .

    Pourquoi quand je souhaite inserer un msg box entre et ça marche pas .

    code complet :


    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
    17
    18
    19
    20
    21
    For i = 1 To n
     
           j = Application.InputBox("Entrer la date d'arrivée de la pièce" & "  " & i, "Durée opératoire pièce")
     
        If j = False Then 
        msgbox("hhhhh")
       Exit Sub
     
     
     
        If Not j Like String(Len(j), "#") Then
     
           MsgBox "Veuillez rentrer un entier positif"
     
        Else
     
           r(i) = h(i) = j
     
        End If
     
     Next i

    merci d'avance !

  4. #4
    Inactif  
    Profil pro
    Inscrit en
    Février 2010
    Messages
    517
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 517
    Par défaut
    cela fonctionne pourtant bien chez moi. Quel est donc le problème précis ?
    Et utilise Exit For (qui fait abandonner la seule boucle), plutôt que Exit Sub (qui fait abandonner la totalité de la procédure SUB°.

  5. #5
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 374
    Billets dans le blog
    8
    Par défaut une idée
    bonjour
    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
    17
    18
    19
    20
    21
    22
     
    For i = 1 To n
     
           j = Application.InputBox("Entrer la date d'arrivée de la pièce" & "  " & i, "Durée opératoire pièce")
     
        If j = False Then        'ici tu remplace "=false" par <0 puisque tu est sencé entrer un chiffre dans ton imputbox
        msgbox("hhhhh")
       Exit Sub
     
     
     
        If Not j Like String(Len(j), "#") Then
     
           MsgBox "Veuillez rentrer un entier positif"
     
        Else
     
           r(i) = h(i) = j
     
        End If
     
     Next i
    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

  6. #6
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Bonsoir à tou(te)s

    Perso, j'aurais vu un code comme celui-là :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    For i = 1 To 10
       j = Application.InputBox("Entrer la durée opératoire de la pièce" & "  " & i, "Durée opératoire pièce")
       While Not IsNumeric(j) Or j < 0 Or j - Int(j) <> 0
          MsgBox "La durée opératoire doit être un entier positif, Recommencez", vbCritical, "Erreur saisie"
          j = Application.InputBox("Recommencez, Entrer la durée opératoire de la pièce" & "  " & i, "Durée opératoire pièce")
       Wend
          p(i) = j
    Next i
    Bonne soirée
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 24/10/2006, 18h51
  2. Interception des commandes in et out
    Par KDD dans le forum x86 16-bits
    Réponses: 13
    Dernier message: 18/12/2002, 17h55
  3. [TP]besoin d'aide pour commandes inconnues
    Par Upal dans le forum Turbo Pascal
    Réponses: 15
    Dernier message: 03/10/2002, 11h48
  4. Réponses: 3
    Dernier message: 02/09/2002, 19h49
  5. Réponses: 2
    Dernier message: 11/08/2002, 22h27

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