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 :

boucle textbox sur multipage


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    90
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 90
    Par défaut boucle textbox sur multipage
    Bonjour,

    Sur un userform, j'ai une cinquantaine de textboxes répartis sur plusieurs pages d'un multipage, et je souhaite récupérer leurs valeurs en cliquant sur un bouton.
    Chaque textbox est intitulé "textboxX" et correspond à la colonne X+1

    J'avais d'abord pensé à cette routine :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Private Sub CommandButton1_Click()
     
        Dim PremLigneVide As Long
       PremLigneVide = Cells(Rows.Count, 1).End(xlUp).Row 'calcul 1ère ligne vide
     
        For k = 1 To 49
            Sheets("Bilan 1").Cells(PremLigneVide, k + 1) = Me.Controls("TextBox" & k)
        Next k
    End Sub
    Mais je tombe sur une erreur avec objet spécifié introuvable, et au débugage je tombe sur k=6 avec donc textbox 6 qui se trouve sur la 2ème page... Donc il ne prend en compte que la 1ère page du multipage...
    En creusant un peu je tombe sur un autre code :

    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
     
    Private Sub CommandButton1_Click()
        Dim Col As Long
        Dim MesTextBox As MSForms.TextBox
        Dim MesPages As MSForms.Page
        Dim PremLigneVide As Long
        PremLigneVide = Cells(Rows.Count, 1).End(xlUp).Row 'calcul 1ère ligne vide
     
        With Me
            For Each MesPages In .MultiPage1.Pages
                For Each MesTextBox In MesPages.Controls
                    Col = Mid(MesTextBox.Name, 8)
                    Sheets("Bilan 1").Cells(PremLigneVide, Col) = MesTextBox.Text
                Next MesTextBox
            Next
        End With
    End Sub
    Mais en l'exécutant j'ai une erreur '13'. Et au débugage je vois qu'elle intervient au premier next, et que le code a réussi à trouver le texte de la première textbox et à mettre la valeur 1 à col.
    Je ne comprends ce qui ne colle pas...

    Merci de votre aide§

  2. #2
    Expert confirmé
    Avatar de jurassic pork
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Décembre 2008
    Messages
    4 247
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Bidouilleur
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2008
    Messages : 4 247
    Par défaut
    Hello,
    la variable MesTextBox peut-être autre chose qu'une TextBox si tu as d'autres types de contrôles sur tes pages (exemple le bouton de commande) alors il ne faut filtrer que les contrôles de type TextBox dans la boucle. Exemple :
    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
    Private Sub CommandButton1_Click()
        Dim Col As Long
        Dim MesControles
        Dim MesPages
        Dim PremLigneVide As Long
        PremLigneVide = Cells(Rows.Count, 1).End(xlUp).row 'calcul 1ère ligne vide
        With Me
            For Each MesPages In .MultiPage1.Pages
                For Each MesControles In MesPages.Controls
                    If TypeName(MesControles) = "TextBox" Then
                        Col = Mid(MesControles.name, 8)
                        ActiveSheet.Cells(PremLigneVide, Col) = MesControles.Text
                    End If
                Next MesControles
            Next
        End With
    End Sub
    Ami calmant, J.P

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    90
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 90
    Par défaut
    Yess ça marche !
    Merci beaucoup !!

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

Discussions similaires

  1. [XL-2016] Difficultés sur: multipage activeX sur feuille + setfocus sur textbox avec touche enter
    Par PlastiBE dans le forum Macros et VBA Excel
    Réponses: 22
    Dernier message: 28/06/2017, 14h14
  2. [VBA-E]ajouter un textbox sur un formulaire par code?
    Par DonKnacki dans le forum Macros et VBA Excel
    Réponses: 20
    Dernier message: 22/03/2006, 09h33
  3. [FLASH 8] boucle fonction sur bouton
    Par bractar dans le forum Flash
    Réponses: 2
    Dernier message: 31/01/2006, 18h34
  4. [Eval] Problème de boucle for sur des tableaux
    Par battle_benny dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 12/01/2006, 23h55
  5. [C#] Compter le nombre de TEXTBOX sur une page ASPX
    Par alain_27 dans le forum ASP.NET
    Réponses: 9
    Dernier message: 27/05/2005, 14h19

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