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 :

VBA Excel sélection multiple


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mai 2006
    Messages : 13
    Par défaut VBA Excel sélection multiple
    Bonjour,
    J'ai une question concernant un tablau croisé dynamique. Je veux créer des groupes en tenant compte des 15 premiers caractères. Je dois donc faire une boucle qui retient les cellules qui seront à groupées et faire le regroupement à la fin. Mais je ne sais ni dans quoi stocker les "addresse" des cellules, ni comment faire une sélection multiple (sur des lignes qui ne sont pas forcément contigües) tout en ne sachant pas le nombre de cellules à regouper d'avance. J'ai essayé avec une variable tableau mais je ne sais pas comment resortir les valeurs du tableau ni comment faire la fameuse sélection multiple.
    Je sais c'est pas simple comme question...
    Merci,
    Voici òu j'en suis arrivé jusqu'a présent:
    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
    23
    24
    25
    26
    Dim nom1 As String
    Dim nom2 As String
    Dim Tableau() As Integer
    Dim Indice As Integer
     
    Indice = 0
        For i = 2 To ActiveSheet.UsedRange.Rows.Count
            nom1 = Range("B" & i)
                For ii = i + 1 To ActiveSheet.UsedRange.Rows.Count
                    nom2 = Range("B" & ii)
                      If nom1 <> "" And nom2 <> "" Then
                        If Left(nom1, 12) = Left(nom2, 12) Then
                         Tableau(Indice) = ii
                         Indice = Indice + 1
                         ReDim Preserve Tableau(Indice)
                         End If
                       End If
                 Next
         'Comment ressortir les valeurs du tableau et faire quelque chose comme:
         'Range("xx,xx,xx").Select
         'Selection.Group
         'ActiveSheet.PivotTables("Tableau croisé dynamique1").PivotFields("code2"). _
            PivotItems("Groupe1").Caption = Left(nom1, 12)
     
         Next
    End Sub

  2. #2
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Par défaut
    Regarde Union dans l'aide
    Après, tu dis
    A+

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mai 2006
    Messages : 13
    Par défaut
    Effectivement ça a l'air interessant mais comment ressortir les valeur du tableau et l'utilisé dans union ?

    Merci

    Olivier

  4. #4
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Par défaut
    Un exemple pour le principe
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub UnionCel()
    Dim Plage As String
    Plage = Range("A1").Address
            For i = 1 To ActiveSheet.UsedRange.Rows.Count
                LaCel = "B" & i + Int(Rnd * 5)
                Set GrandePlage = Application.Union(Range(Plage), Range("B" & i + Int(Rnd * 5)))
                Plage = GrandePlage.Address
            Next
            MsgBox GrandePlage.Address
    End Sub
    De préférence, teste ça pour une feuille renseignée
    "Range("B" & i + Int(Rnd * 5)))" me sort un N° de ligne alléatoire
    A+

Discussions similaires

  1. Récupérer l'adresse d'une zone de sélection
    Par belfaigore dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 15/07/2020, 15h18
  2. [VBA-Excel] - Empêcher sélection de certaines cellules
    Par Chewi dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 31/01/2007, 10h04
  3. [VBA-excel] Selection multiple de ligne
    Par DVano dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 18/10/2006, 12h32
  4. Réponses: 7
    Dernier message: 11/08/2006, 14h26
  5. VBA EXCEL - Sélection d'une ligne suivant saisie
    Par brethomeau dans le forum Macros et VBA Excel
    Réponses: 48
    Dernier message: 15/11/2005, 17h41

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