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 Sélection d'un intervalle dans un For Each [XL-2013]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Décembre 2009
    Messages
    117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Secteur : Santé

    Informations forums :
    Inscription : Décembre 2009
    Messages : 117
    Par défaut VBA Sélection d'un intervalle dans un For Each
    Bonjour,

    Je ne comprend pas pourquoi ma macro ne sélectionne pas l'intervalle de la ligne de code suivante;

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For Each X In Sheets("Base").Range("E3:" & Sheets("Base").Range("E12").End(xlUp).Address)
    VBA va plutôt me retourner les trois premières valeurs de la colonne E. Il ne tiens pas compte de mon intervalle de E3 à E12.

    quelqu'un sait pourquoi?

    Merci à vous!!

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    C'est parce que les cellules de E6 à E11 sont vides.

    Si vous souhaitez l'intervalle E3:E12, il ne faut pas demander la dernière cellule non vide de cette aire par rapport à E12.

    Changez votre formule For Each :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For Each X In Sheets("Base").Range("E3:" & Sheets("Base").Range("E12").Address)

    Le programme pour tester :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub Essai()
     
    Dim X As Range
     
    'For Each X In Sheets("Base").Range("E3:" & Sheets("Base").Range("E12").End(xlUp).Address)
    For Each X In Sheets("Base").Range("E3:" & Sheets("Base").Range("E12").Address)
        MsgBox X & Chr(10) & X.Address
     
    Next X
     
      MsgBox Sheets("Base").Range("E12").End(xlUp).Address
     
    End Sub
    Cordialement.

  3. #3
    Expert éminent
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Par défaut

    Bonjour, bonjour !

    Franchement pour afficher le contenu d'une plage de cellules, il y a plus simple !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Sub Demo()
             Dim Rg As Range
        For Each Rg In Worksheets("Base").Range("E3:E12")
              If Rg.Text > "" Then T$ = T$ & vbLf & Rg.Address(0, 0) & " : " & Rg.Text & vbLf
        Next
              If T > "" Then MsgBox T
    End Sub
    __________________________________________________________________________________________

    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion …

  4. #4
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Décembre 2009
    Messages
    117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Secteur : Santé

    Informations forums :
    Inscription : Décembre 2009
    Messages : 117
    Par défaut résolu
    Merci,

    ça marche super bien. merci de votre temps précieux. :-)

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

Discussions similaires

  1. [XSLT][débutant] Problème xsl:value-of dans xsl:for-each
    Par Choubie dans le forum XSL/XSLT/XPATH
    Réponses: 3
    Dernier message: 09/05/2007, 16h30
  2. [XSLT] Element parent dans un For-each
    Par Katachana dans le forum XSL/XSLT/XPATH
    Réponses: 3
    Dernier message: 20/04/2007, 09h39
  3. [XSLT] Number dans un for-each
    Par stepd dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 18/08/2006, 13h40
  4. [VBA] sélection d'un élément dans une liste
    Par menguygw dans le forum Access
    Réponses: 3
    Dernier message: 26/04/2006, 12h18
  5. [XML-XPATH] Problème dans un for each
    Par stailer dans le forum XSL/XSLT/XPATH
    Réponses: 1
    Dernier message: 26/12/2005, 12h11

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