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 :

target.address : localiser un changement de valeur


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
    Octobre 2008
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 69
    Par défaut target.address : localiser un changement de valeur
    Bonjour,

    je cherche à ce que, lorsque l'utilisateur rempli une cellule, je localise la ligne afin d'utiliser le contenu d'une autre colonne (de cette ligne). En d'autre terme, l'utilisateur entre un numero en L8. Je veux recuperer la valeur de G8. J'ai actuellement ce script :
    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 Worksheet_Change(ByVal target As Range)
        Dim rg As Range
        Dim lastrow As Integer
        With ActiveSheet
            lastrow = .Cells(.Rows.Count, "G").End(xlUp).Row
        End With
     
        'Ne rien faire si plus d'une cellule est changé ou si le contenu est supprimé
        If target.Cells.Count > 1 Or IsEmpty(target) Then Exit Sub
     
        'Vérifier que l'action concerne bien les colonnes des mois (de I à T)
        If Not Application.Intersect(target, Range("I8:T" & lastrow)) Is Nothing Then
     
        MsgBox target.Address
     
        End If
    End Sub
    Ce code fonctionne, mais je récupère $L$8. Je ne sais pas quoi faire avec ça. Je souhaiterais acceder à G8.

    Merci d'avance

  2. #2
    Membre expérimenté
    Homme Profil pro
    Technicien Méthodes
    Inscrit en
    Mars 2013
    Messages
    128
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Technicien Méthodes
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Mars 2013
    Messages : 128
    Par défaut
    Bonjour,

    tu y etais presque, il te suffit de remplacer

    par

    pour les lignes (ce qui t'interesse si j'ai bien lu)

    ou alors

    pour la colonne

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 69
    Par défaut
    Merci Guiiand c'est parfait.

    Bonjour,
    Si target est la cellule G8, alors la cellule L8 est alors définie par un décallage de 0 lignes et 5 colonnes :
    Code :Sélectionner tout - Visualiser dans une fenêtre à parttarget.Offset(0, 5)Pour obtenir une adresse dans le format relatif (L8) plutôt qu'absolu ($L$8), il faut utiliser les paramètres de la fonction Adress. Exemples, obtenu dans la fenêtre Debug :
    Code :Sélectionner tout - Visualiser dans une fenêtre à part12345678 ?range("A1").Address(False, False)
    A1
    ?range("A1").Address(True, True)
    $A$1
    ?range("A1").Address(True, False)
    A$1
    ?range("A1").Address(False, True)
    $A1
    J'avais pensé à la solution offset mais ça me semblait inélégant.

    rdurupt > Oui je sais bien, c'est tout bête mais je suis très loin d'être aguéri en vba (et même en prog en général). Mais j'apprends tout les jours.

    Merci à vous.

  4. #4
    Membre Expert
    Femme Profil pro
    Data engineer
    Inscrit en
    Juin 2007
    Messages
    673
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Data engineer
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2007
    Messages : 673
    Par défaut
    Bonjour,
    Si target est la cellule G8, alors la cellule L8 est alors définie par un décallage de 0 lignes et 5 colonnes : Pour obtenir une adresse dans le format relatif (L8) plutôt qu'absolu ($L$8), il faut utiliser les paramètres de la fonction Adress. Exemples, obtenu dans la fenêtre Debug :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    ?range("A1").Address(False, False)
    A1
    ?range("A1").Address(True, True)
    $A$1
    ?range("A1").Address(True, False)
    A$1
    ?range("A1").Address(False, True)
    $A1

  5. #5
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    Je ne comprends pas tu sais récupérer
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    lastrow = .Cells(.Rows.Count, "G").End(xlUp).Row
    Et pas

  6. #6
    Membre Expert
    Homme Profil pro
    Retraité
    Inscrit en
    Avril 2011
    Messages
    1 858
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Avril 2011
    Messages : 1 858
    Par défaut
    Bonjour,

    Un exemple de code pour retourner la valeur de la colonne G qui se trouve sur la même ligne que la cellule modifiée.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Private Sub Worksheet_Change(ByVal target As Range)
    Dim lastrow As Integer
        If target.Count > 1 Or IsEmpty(target) Then Exit Sub
        lastrow = Cells(Rows.Count, "G").End(xlUp).Row
        If Not Application.Intersect(target, Range("I8:T" & lastrow)) Is Nothing Then
            MsgBox "Valeur de la cellule correspondante en colonne G :" & Range("G" & target.Row).Value
        End If
    End Sub
    Cordialement.

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 19/03/2014, 20h34
  2. Réponses: 2
    Dernier message: 23/01/2006, 11h55
  3. Changement de valeur
    Par Anduriel dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 27/11/2005, 00h31
  4. Réponses: 1
    Dernier message: 29/09/2005, 11h10
  5. Intercepter le changement de valeur d'une variable
    Par Captain_JS dans le forum C++Builder
    Réponses: 5
    Dernier message: 07/01/2005, 08h04

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