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 :

[E03][VBA][Données] - Limiter une fonction sur dernière ligne non vide


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 37
    Points : 20
    Points
    20
    Par défaut [E03][VBA][Données] - Limiter une fonction sur dernière ligne non vide
    Bonjour,

    Je débute en VBA et je rencontre systématiquement le problème suivant. Je ne sais pas limiter ma commande sur la dernière ligne de ma feuille.
    Exemple, j'utilise le code suivant pour que :
    Si champ E= "vide" alors colonne D= valeur colonne B
    Si champ E= "non vide" alors colonne D= valeur colonne E
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Sub ColonneD()
        Range("D2").Select
        ActiveCell.FormulaR1C1 = "=IF(RC[1]="""",RC[-2],RC[1])"
        Selection.AutoFill Destination:=Range("D2:D4")
        Range("D2:D4").Select
        Range("D2").Select
    End Sub
    Je voudrais que cette commande s'effectue tant que la Colonne A n'est pas vide.
    Plus généralement comment faire une boucle jusqu'à dernière ligne non vide d'une feuille.

    Merci d'avance pour vos lumières

  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
    Points : 15 543
    Points
    15 543
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
        NoCol = 1
        DerniereLigne = Cells(Columns(NoCol).Cells.Count, NoCol).End(xlUp).Row
    Pour avoir la dernière ligne renseignée de la colonne A

  3. #3
    Membre confirmé
    Inscrit en
    Janvier 2008
    Messages
    467
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 467
    Points : 493
    Points
    493
    Par défaut
    Bonjour
    un exemple à tester pour boucler sur la colonne A tant que cellule non vide
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Sub ColonneA()
    Dim i As Integer
    i = 2
    Do Until IsEmpty(Cells(i, 1)) ' commencer par la cellule A2
       If Cells(i, 5) <> "" Then 'teste si la cellule E2 contient une valeur
          Cells(i, 4) = Cells(i, 5) ' si oui affecte ça valeur à la colonne D2
         Else ' si non
          Cells(i, 4) = Cells(i, 2) 'affecte la valeur de B2 à D2
         End If
       i = i + 1 'incrémenter le numéro de la ligne
     Loop ' fin de la boucle
    End Sub
    Abed_H

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 37
    Points : 20
    Points
    20
    Par défaut
    Merci, j'avoue que vos codes sont plus "propres" que mes tentatives.

    J'avoue que j'ai du mal avec les boucles et l'utilisation des variables

    Mais j'ai bon espoir, je suis en train d'ingurgiter le document VBA débutant...

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

Discussions similaires

  1. Appliquer une fonction sur les lignes d'un fichier
    Par sconrad dans le forum Langage
    Réponses: 2
    Dernier message: 05/07/2012, 15h26
  2. [XL-2003] Récupérer une cellule de la dernière ligne non vide d'un tableau
    Par christoff916 dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 17/08/2011, 14h22
  3. Réponses: 6
    Dernier message: 10/03/2011, 09h37
  4. Réponses: 1
    Dernier message: 30/12/2010, 09h31
  5. Ajouter des données après la dernière ligne non vide
    Par jnmab dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 14/11/2007, 10h21

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