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 l'adresse d'une zone de sélection


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
    Janvier 2005
    Messages
    135
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 135
    Par défaut Récupérer l'adresse d'une zone de sélection
    Bonjour,

    J'utilise un formulaire dans lequelle je voudrais afficher dans 2 Textbox la case de début et de fin d'une zone de sélection.
    Typiquement, l'utilisateur sélectionne une zone de cellule, par exemple de A1 à K7 et moi je cherche une fonction ou une methode permettant de renvoyer "A1:K7".

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    135
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 135
    Par défaut
    J'ai développé une petite macro ... si quelqu'un connait une methode plus simple, plus optimisé, se serait bienvenu
    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
    '
    'Renvoie la zone sélectionné
    '
    Public Function ZoneDeSelection(Optional RowAbsolute As Boolean = True, Optional ColumnAbsolute As Boolean = True, Optional ReferenceStyle As XlReferenceStyle = xlA1) As String
        Dim c As Range
        Dim FirstCell, LastCell, Zone As String
     
     
        FirstCell = ActiveCell.Address(RowAbsolute, ColumnAbsolute, ReferenceStyle)
        For Each c In Selection
            'MsgBox c.Address(RowAbsolute, ColumnAbsolute, ReferenceStyle)
            LastCell = c.Address(RowAbsolute, ColumnAbsolute, ReferenceStyle)
        Next c
     
        If FirstCell = LastCell Then Zone = FirstCell Else Zone = FirstCell & ":" & LastCell
     
        ZoneDeSelection = Replace(Zone, "$", "")
    End Function

  3. #3
    Invité de passage
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2019
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Charente (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2019
    Messages : 1
    Par défaut
    Je vois que les messages date un peu mais je pense qu'il est possible d'obtenir ce résultat en utilisant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    '
    Range("A1").CurrentRegion.Address()
    Si jamais ça peut être utile à quelqu'un

  4. #4
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 176
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 176
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    J'utilise un formulaire dans lequelle je voudrais afficher dans 2 Textbox la case de début et de fin d'une zone de sélection.
    Typiquement, l'utilisateur sélectionne une zone de cellule, par exemple de A1 à K7 et moi je cherche une fonction ou une methode permettant de renvoyer "A1:K7".
    Une sélection de cellules est un objet Selection

    Un objet a des propriétés dont Address donc MsgBox Selection.Address affichera l'adresse de la sélection et si l'on souhaite connaître l'adresse complète de la sélection pn ajoutera l'argument External soit MsgBox Selection.Address(External:=True)

    On peut également intercepter l'action de sélectionner une plage de cellules à l'aide de la procédure événementielle Worksheet_SelectionChange
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub Worksheet_SelectionChange(ByVal Target As Range)
      MsgBox Target.Address(External:=True)
    End Sub
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

Discussions similaires

  1. récupérer les valeurs d'une zone de liste à sélection multiple
    Par garsflo dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 09/07/2009, 21h19
  2. [VBA-E]récupérer l'adresse d'une cellule
    Par julyBL dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 06/06/2006, 19h29
  3. Réponses: 2
    Dernier message: 12/04/2006, 10h00
  4. Réponses: 3
    Dernier message: 22/03/2006, 09h47
  5. Récupérer l'adresse d'une autre fenêtre
    Par AlLutun dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 16/11/2004, 10h19

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