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 :

Derniere ligne non vide=nbre de ligne max dans excel [XL-2007]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2006
    Messages : 45
    Par défaut Derniere ligne non vide=nbre de ligne max dans excel
    Bonjour,

    Je me suis construit une petite fonction pour aller récupérer le n° de la dernière ligne non nulle d'une feuille :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Function derniereligne(liste As String) As Long
    With Worksheets(liste)
        derniereligne = .Range("A1").End(xldown).Row
        MsgBox "Numéro de la dernière ligne : " & derniereligne
        End With
    End Function
    et pour une de mes feuilles du classeur, la fonction me renvoie systématiquement la valeur 1 048 576, soit le nombre de ligne max dans excel, alors que la dernière ligne non nulle est la n°70...
    D'ou peut venir le probleme?

    Merci pour vos lumieres!

  2. #2
    Membre Expert
    Inscrit en
    Octobre 2010
    Messages
    1 401
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 1 401
    Par défaut
    Bonjour polo92;

    Et avec ceci, est-ce mieux ?

    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
    Sub Dernieres()
     Liste = 1
     
     With Worksheets(Liste)
     
     Set rg = .Cells.Find(what:="*", After:=.[A1], LookIn:=xlValues, LookAt:=xlPart, SearchFormat:=False, SearchOrder:=xlByRows, SearchDirection:=xlPrevious, MatchCase:=False)
    If rg Is Nothing Then DernLigne = 1 Else DernLigne = rg.Row
     
     Set rg = .Cells.Find(what:="*", After:=.[A1], LookIn:=xlValues, LookAt:=xlPart, SearchFormat:=False, SearchOrder:=xlByColumns, SearchDirection:=xlPrevious, MatchCase:=False)
    If rg Is Nothing Then derniereColonne = 1 Else derniereColonne = rg.Column
     
    MsgBox DernLigne & " " & derniereColonne
    End With
     
    End Sub
    Cordialement
    Docmarti

  3. #3
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 374
    Billets dans le blog
    8
    Par défaut re
    Bonjour

    en fait pour avoir la derniere ligne utilisée dans une colonne

    il faut utiliser un autre argument

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Function derniereligne(liste As String) As Long
    With Worksheets(liste)
        derniereligne = .Range("A"& rows.count).End(xlup).Row
        MsgBox "Numéro de la dernière ligne : " & derniereligne
        End With
    End Function
    xldown part d'en haut vers le bas donc si tu a une cellule vide au milieu la réponse sera fausse

    xlup part d'en bas vers le haut

    ensuite cette méthode te donne la dernière ligne utilisée dans la colonne précisée ici en l'occurrence la colonne "A"

    maintenant si tu cherche la dernière ligne utilisée dans le sheets(feuille)
    toute colonne confondues sert toi de usedrange.row
    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

  4. #4
    Expert éminent


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Par défaut
    Bonsoir,

    il y as quoi dans la colonne A de la feuille ou cela ne fonctionne pas ? n'est-elle pas vide ?

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2006
    Messages : 45
    Par défaut
    Merci à vous 3 pour vos réponses.

    En fait effectivement, ça va à la derniere ligne quand la colonne est vide...je m'en suis aperçu en faisant des tests.

    J'ai repris le code de patricktoulon pour éviter le probleme d'une cellule vide.

  6. #6
    Membre Expert
    Inscrit en
    Octobre 2010
    Messages
    1 401
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 1 401
    Par défaut
    Bonjour patricktoulon

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     derniereligne = .Range("A"& rows.count).End(xlup).Row
    Cette méthode, très utilisée, est fiable pour trouver la dernière ligne non vide d'une seule colonne.

    Mais qu'en est-il si je veux trouver la dernière ligne non vide de plusieurs colonnes? Elle ne fonctionne plus.

    C'est pourquoi je préfère utiliser Find qui permet de rechercher sur plusieurs colonnes ou dans un champ spécifique. Voir le classeur joint.


    maintenant si tu cherche la dernière ligne utilisée dans le sheets(feuille)
    toute colonne confondues sert toi de usedrange.row
    UsedRange est à éviter car il est reconnu pour n'avoir aucune fiabilité en ce qui concerne la dernière ligne contenant au moins une valeur.

    Cordialement

    Docmarti
    Fichiers attachés Fichiers attachés

  7. #7
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 374
    Billets dans le blog
    8
    Par défaut re
    Bonjour docmarti

    je ne suis pas sur que tu es raison

    parce que non seulement le résultat est important mais aussi le temps

    exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set r = Worksheets("Feuil1").Range("A:D")
    quand tu envoie cette ref de cellule dans ta fonction

    la fonction cherche dans les 4 colonnes jusqu'à a la dernière ligne
    car l'argument est "*" donc toutes les cellules seront visitée et je dis bien toutes

    même si ca n'est pas nécessaire

    c'est mon opinion

    a méditer

    Au plaisir
    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

  8. #8
    Membre Expert
    Inscrit en
    Octobre 2010
    Messages
    1 401
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 1 401
    Par défaut
    Bonjour patricktoulon

    Tu soulèves là une question intéressante : la rapidité de la fonction FIND.

    La fonction RECHERCHE de Excel est optimisée pour effectuer une recherche en moins de 1/10 ième de seconde, et cela même si la recherche s'effectue sur 1,048,576 lignes et 16,384 colonnes.

    Et comme la fonction FIND de VBA utilise la fonction RECHERCHE de Excel, le résultat est instantané.

    De plus la fonction FIND de VBA peut limiter sa recherche à un champ, ce qui est très utile pour connaître la dernière ligne non vide d'un champ.

    Cordialement

    Docmarti

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

Discussions similaires

  1. selectionner la derniere ligne non vide
    Par kefinacib dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 15/08/2012, 03h33
  2. Calcul de la somme d'une colonne apres la derniere ligne non vide
    Par lilp1 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 05/06/2009, 11h14
  3. compter sur une ligne à partir de derniere cellule non vide
    Par oscar.cesar dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 03/04/2009, 18h23
  4. [vba Excel] Obtenir dernier cellule non vide d'une ligne
    Par cow_boy dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 04/05/2007, 10h07
  5. [VBA-E]derniere ligne non vide
    Par delamarque dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 28/07/2006, 10h48

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