Recuperer les numeros de colonne en selection multiple
Résolu
eeam78
Messages postés
17
Date d'inscription
Statut
Membre
Dernière intervention
-
eeam78 Messages postés 17 Date d'inscription Statut Membre Dernière intervention -
eeam78 Messages postés 17 Date d'inscription Statut Membre Dernière intervention -
A voir également:
- Recuperer les numeros de colonne en selection multiple
- Déplacer colonne excel - Guide
- Comment récupérer les messages supprimés sur whatsapp - Guide
- Comment récupérer les numéros de téléphone supprimer - Accueil - Android
- Trier colonne excel - Guide
- Colonne word - Guide
9 réponses
Bonjour,
Selection est un objet de type RANGE
Il a donc une propriété Columns
Tu peux donc faire :
Selection est un objet de type RANGE
Il a donc une propriété Columns
Tu peux donc faire :
For Each C In Selection.Columns Debug.Print "Colonne :" & C.Column Next
aie ! ....
je voulais adapter type de la recherche ( le "C" ) , alors qu'il suffisait d'adapter la zone de recherche (le "Selection") .
voilà pourquoi je trouvais pas ... c'est super simple .
dslé ... :-(
merci jordane45 !
eeam.
je voulais adapter type de la recherche ( le "C" ) , alors qu'il suffisait d'adapter la zone de recherche (le "Selection") .
voilà pourquoi je trouvais pas ... c'est super simple .
dslé ... :-(
merci jordane45 !
eeam.
re bjr ...
néanmoins : toujours sous les mêmes hypotheses , pourquoi ne peut on pas appeler directement le xieme element selectionné ??
En effet, si je veux la 4ieme colonne seulement , je ne peut pas faire
pourquoi me donne t il la 4eme colonne apres la 1ere ? c'est la 4eme parmi les selectionnees que je devrait recupérer . non ?
merci de vos eclaircissements ...
eeam
néanmoins : toujours sous les mêmes hypotheses , pourquoi ne peut on pas appeler directement le xieme element selectionné ??
En effet, si je veux la 4ieme colonne seulement , je ne peut pas faire
Debug.Print "4eme Colonne :" & Selection.Columns(4).Column
pourquoi me donne t il la 4eme colonne apres la 1ere ? c'est la 4eme parmi les selectionnees que je devrait recupérer . non ?
merci de vos eclaircissements ...
eeam
Bonsoir eeam78,
Lorsque tu fais une sélection multiple, celle-ci comporte donc
à l'évidence plusieurs zones, dont le nombre est donné par
Selection.Areas.Count ; voici un petit exercice :
Sur ta feuille, fais cette sélection multiple :
colonnes C:E, I:L, O:Q
L'instruction : MsgBox Selection.Areas.Count
affichera 3, car il y a 3 zones.
Si par exemple tu veux modifier la largeur de la colonne K,
qui est la 3ème colonne de ta 2ème zone :
Si ton problème est réglé, merci d'aller en haut de page
pour cliquer sur « Marquer comme résolu ».
Cordialement. 😊
Lorsque tu fais une sélection multiple, celle-ci comporte donc
à l'évidence plusieurs zones, dont le nombre est donné par
Selection.Areas.Count ; voici un petit exercice :
Sur ta feuille, fais cette sélection multiple :
colonnes C:E, I:L, O:Q
L'instruction : MsgBox Selection.Areas.Count
affichera 3, car il y a 3 zones.
Si par exemple tu veux modifier la largeur de la colonne K,
qui est la 3ème colonne de ta 2ème zone :
Selection.Areas(2).Columns(3).ColumnWidth = 50
Si ton problème est réglé, merci d'aller en haut de page
pour cliquer sur « Marquer comme résolu ».
Cordialement. 😊
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Bonjour Albkan , et merci de ta reponse .
En effet cela me rapproche de la solution .
Neanmoins, cela m'oblige a connaitre la zone de la colonne souhaitée.
Alors que ce qui m'interesse ici c'est de selectionner la xième colonne .
exemple : dans ton exemple de selection du dessus C:E, I:L, O:Q , la colonne K est la 6ieme de la selection.
mais si je selectionne C:F , J:L , O:Q
ton instruction ne me donnera pas la colonne K , alors que celle ci est encore en 6ieme position .
mais peut-etre n'est ce pas possible ...
merci en tt cas .
eeam
En effet cela me rapproche de la solution .
Neanmoins, cela m'oblige a connaitre la zone de la colonne souhaitée.
Alors que ce qui m'interesse ici c'est de selectionner la xième colonne .
exemple : dans ton exemple de selection du dessus C:E, I:L, O:Q , la colonne K est la 6ieme de la selection.
mais si je selectionne C:F , J:L , O:Q
ton instruction ne me donnera pas la colonne K , alors que celle ci est encore en 6ieme position .
mais peut-etre n'est ce pas possible ...
merci en tt cas .
eeam
Tu peux essayer ça et me dire si ça te va ?
Sub colTest() Dim ColSelect As Areas Dim nbCol As Long 'Colonnes selectionnées Set ColSelect = Selection.Areas 'Nombre de zone selectionnées (colonnes y compris celles contigues) nbCol = ColSelect.Count 'Liste des colonnes selectionnées For Each C In ColSelect Debug.Print "Colonne :" & C.Column Next 'On modifie la largeur d'une colonne en particulier (ici la deuxième de ma selection) ColSelect(2).ColumnWidth = 5 End Sub
pas vraiment en fait ... :
par exemple , la boucle FOR ne me liste pas les colonnes , mais liste la 1ere colonne de chaquie zone ; par exemple ds la seletion C:E, I:L, O:Q
il donne "colonne 3 , colonne 9, colonne 15" .
par ailleurs , chez moi, le ColSelect(2).ColumnWidth ne passe pas ..
dslé.
par exemple , la boucle FOR ne me liste pas les colonnes , mais liste la 1ere colonne de chaquie zone ; par exemple ds la seletion C:E, I:L, O:Q
il donne "colonne 3 , colonne 9, colonne 15" .
par ailleurs , chez moi, le ColSelect(2).ColumnWidth ne passe pas ..
dslé.
Bon finalement je pense qu'en stockant dans un array c'est plus simple.
Voici un exemple complet.... dis moi ce que tu en penses.
Cordialement,
Jordane
Voici un exemple complet.... dis moi ce que tu en penses.
Sub colTest() Dim ColSelect As Areas Dim nbCol As Long Dim tblCol() Dim x As Long Dim numColonne As Long Dim monChoix As Long 'Colonnes selectionnées Set ColSelect = Selection.Areas 'Nombre de zone selectionnées (colonnes y compris celles contigues) nbCol = ColSelect.Count 'On Alimente l'array avec la Liste des colonnes selectionnées ReDim Preserve tblCol(0) For Each A In ColSelect If A.Columns.Count > 1 Then For Each C In A.Columns x = UBound(tblCol) + 1 ReDim Preserve tblCol(x) tblCol(x - 1) = C.Column Next Else x = UBound(tblCol) + 1 ReDim Preserve tblCol(x) tblCol(x - 1) = A.Column End If Next 'On affiche la liste des colonnes For i = 0 To UBound(tblCol) - 1 numColonne = tblCol(i) Debug.Print "Colonne N° " & numColonne & " => " & LettreColonne(numColonne) Next 'On cible une colonne en particulier (via son numero d'ordre ) monChoix = 3 'je cible la troisième colonne de ma liste ActiveSheet.Columns(tblCol(monChoix - 1)).Interior.Color = 5 End Sub Function LettreColonne(NumCol As Long) As String Dim reste, quotient As Long quotient = Int(NumCol / 26) reste = NumCol Mod 26 If quotient = 0 And reste = 0 Then Exit Function End If If quotient = 0 Then LettreColonne = Chr(64 + reste) Else If reste = 0 Then quotient = quotient - 1 If quotient = 0 Then LettreColonne = Chr(64 + 26) Else LettreColonne = Chr(64 + quotient) & Chr(64 + 26) End If Else LettreColonne = Chr(64 + quotient) & Chr(64 + reste) End If End If End Function
Cordialement,
Jordane
Merci Jordane,
En effet, ca fonctionne .
Je m'en étais "tiré" en faisant simplement une boucle FOR en incrementant un compteur a chaque colonne et en testant si le compteur etait = à x .
Mais j'en conviens ce n'est pas très élégant comme programmation , et souhaitais une approche, sinon plus simple, en tout cas plus académique . ce qui est fait . merci encore .
eeam.
En effet, ca fonctionne .
Je m'en étais "tiré" en faisant simplement une boucle FOR en incrementant un compteur a chaque colonne et en testant si le compteur etait = à x .
Mais j'en conviens ce n'est pas très élégant comme programmation , et souhaitais une approche, sinon plus simple, en tout cas plus académique . ce qui est fait . merci encore .
eeam.