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 :

allègement code ouverture d'un formulaire [XL-2003]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de bosk1000
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    706
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 706
    Par défaut allègement code ouverture d'un formulaire
    bonsoir a tous

    à l'initialisation d'un formulaire, j'ai beaucoup de combobox qui vienne cherchez la meme source de liste.

    comme elle commence toutes par "cbo_nom_" la suite étant colis ou noel ou scolaire, etc... et ensuite un numéro de 1 à 10

    voici un des code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    For i = 1 To 10
    Me.Controls("cbo_nom_colis" & i).RowSource = "source!a2:a" & Range("source!a65536").End(xlUp).Row
         Me.Controls("cbo_nom_colis" & i).MatchEntry = fmMatchEntryComplete ' permet d'ecrire les nom dans une zone de liste deroulante
         Me.Controls("cbo_nom_colis" & i).MatchRequired = True 'pour forcer une saisie correct
    Next i
     
    For i = 1 To 10
    Me.Controls("cbo_nom_noel" & i).RowSource = "source!a2:a" & Range("source!a65536").End(xlUp).Row
         Me.Controls("cbo_nom_noel" & i).MatchEntry = fmMatchEntryComplete ' permet d'ecrire les nom dans une zone de liste deroulante
         Me.Controls("cbo_nom_noel" & i).MatchRequired = True 'pour forcer une saisie correct
    Next i
    je met ici colis et noel, mais est-il possible de ne créer qu'une fois ce code de manière a ce qu'il soit valable pour toutes les combobox qui débute par "cbo_nom_"

  2. #2
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    pas testé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Dim i As Byte, j As Byte
    Dim typ
    typ = Array("colis", "noel")
    For j = 0 To UBound(typ)
        For i = 1 To 10
            With Me.Controls("cbo_nom_" & typ(j) & i)
                .RowSource = "source!a2:a" & Range("source!a65536").End(xlUp).Row
                .MatchEntry = fmMatchEntryComplete ' permet d'ecrire les nom dans une zone de liste deroulante
                .MatchRequired = True 'pour forcer une saisie correct
            End With
        Next i
    Next j

  3. #3
    Membre éclairé Avatar de bosk1000
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    706
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 706
    Par défaut
    ton code est parfait
    merci

    par contre niveau compréhension
    je pêche
    puis-je te demander quelque précision pour ma compréhension ?



    je ne comprend pas la fonction array (le mode f1 est pas très clair)

    pourquoi m'est tu "dim type" et rien d'autre après

    lorsque tu met
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    For j = 0 To UBound(typ)
    c'est pour spécifier d'effectuer l'operation sur toutes la liste des mot clef (colis, noel, etc...) ?

    dernier point
    tu met i en byte, moi jusqu'ici je met en integer
    qu'est-ce qui est plus pertinent

  4. #4
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Array: tableau
    Dim typ (ça reste un variant)
    Ubound(typ) le nombre d'éléments
    tu as seulement 10 boucle, byte suffit

    ci joint lien http://silkyroad.developpez.com/VBA/LesVariables/

  5. #5
    Membre éclairé Avatar de bosk1000
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    706
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 706
    Par défaut
    merci

    la partie array, me reste encore a decouvrir
    merci

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

Discussions similaires

  1. Problème code ouverture formulaire
    Par macaby dans le forum IHM
    Réponses: 2
    Dernier message: 05/06/2011, 21h23
  2. [XL-2003] Simplification d'un code a l'ouverture d'un formulaire
    Par bosk1000 dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 12/12/2009, 21h25
  3. Réponses: 5
    Dernier message: 29/12/2005, 13h47
  4. code pour fermer un formulaire
    Par rippey dans le forum IHM
    Réponses: 2
    Dernier message: 21/10/2003, 15h51
  5. lecture de son à l'ouverture d'un formulaire
    Par cynferdd dans le forum IHM
    Réponses: 4
    Dernier message: 16/06/2003, 15h31

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