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 :

Récupérer la donnée à partir de InputBox et exécuter la suite de la macro avec cette réponse


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Employé administratif
    Inscrit en
    Février 2014
    Messages
    78
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Employé administratif

    Informations forums :
    Inscription : Février 2014
    Messages : 78
    Par défaut Récupérer la donnée à partir de InputBox et exécuter la suite de la macro avec cette réponse
    Bonjour,

    À partir de l'exemple ci-dessous, je souhaiterais récupérer la donnée saisie dans une InputBox, et appliquer la suite de la macro en récupérant l'information saisie de la InputBox.
    Je rencontre une erreur d'exécution à la ligne reprise dans la macro ci-dessous :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    c = ActiveCell.Offset(0, réponse)
    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
    Sub Variations()
     
    Cells(1,1).Select
    Selection.CurrentRegion.Select
    nb_ligne = Selection.Rows.Count
    Range(ActiveCell, Selection.End(xlToRight)).Select
    Selection.Name = "tete_de_ligne"
    Range("tete_de_ligne").Find("Portefeuilles concernés").Select
     
    depart:
    réponse = InputBox("Taper le code portefeuille")
    For compteur 1 To Nb_ligne -1
    ActiveCell.Offset(1,0).Select
    c = ActiveCell.Offset(0, réponse)
    If ActiveCell.Cells = c Then
    ActiveCell.Interior.ColorIndex = 44
    End If
    Next compteur
    End Sub
    Je ne vois pas comment corriger la macro.

    Vous en remerciant par avance de l'aide apportée.

    Cordialement.

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Bonjour,

    Si c'est vraiment un numéro de colonne que le InputBox te retourne, essaie ainsi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    réponse = CLng(InputBox("Taper le code portefeuille"))

    Cells attend un numérique comme numéro de colonne et Inputbox retourne une chaîne de caractères

    PS: essaie d'éliminer tous les Select/Selection qui ne font que ralentir les macros...

  3. #3
    Membre confirmé
    Homme Profil pro
    Employé administratif
    Inscrit en
    Février 2014
    Messages
    78
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Employé administratif

    Informations forums :
    Inscription : Février 2014
    Messages : 78
    Par défaut Récupérer la donnée à partir de InputBox et exécuter la suite de la macro avec cette réponse
    Bonjour,

    Dans le InputBox, je saisis le code du portefeuille.
    La cellule active se décale vers le bas, cellule par cellule.
    Si le code du portefeuille dans la cellule active est identique à celui que j'ai saisis dans le InputBox, colorie cette cellule en orange.

    Dans la réponse apportée ci-dessus, Visual Basic indique un débogage à cette ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    c = ActiveCell.Offset(0, réponse)
    Peux-tu également me montrer un exemple comment éliminer tous les Select/Selection qui ne font que ralentir les macros ?
    Je ne vois pas comment éviter les erreurs de syntaxe dans VBA.

    Merci par avance de ton aide

    Cordialement.

  4. #4
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Je ne suis pas certain de ce que tu cherches à faire, mais le code suivant va mettre en orange les cellules de la dernière colonne qui correspond à la réponse du Inputbox
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
        Dim I As Long, nbLignes As Long, nbColonnes As Long
        Dim Reponse
     
        nbLignes = Cells(Rows.Count, "A").End(xlUp).Row
        nbColonnes = Cells(1, Columns.Count).End(xlToLeft).Column
     
        Reponse = InputBox("Taper le code portefeuille")
     
        For I = 2 To nbLignes
            If Cells(I, nbColonnes) = Reponse Then
                Cells(I, nbColonnes).Interior.ColorIndex = 44
            End If
        Next
    Si le code est alphanumérique, tu pourrais vérifier sans te préoccuper de la casse
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
           If LCase(Cells(I, nbColonnes)) = LCase(Reponse) Then
    Tu pourras alors entrer un code en minuscule ou majuscule et la macro va le trouver.

Discussions similaires

  1. Récupérer des données à partir d'une URL ?
    Par Bebert71 dans le forum Général JavaScript
    Réponses: 12
    Dernier message: 19/02/2009, 12h53
  2. Réponses: 5
    Dernier message: 17/06/2008, 17h05
  3. Récupérer les données à partir des zones de textes
    Par TSniper dans le forum NetBeans
    Réponses: 12
    Dernier message: 09/04/2008, 12h46
  4. récupérer les données à partir d'un formaulaire infopath
    Par ahmedmido dans le forum SharePoint
    Réponses: 6
    Dernier message: 07/04/2008, 15h24
  5. Réponses: 11
    Dernier message: 13/07/2006, 16h15

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