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 :

Selection d'une selection dans un filtre


Sujet :

Macros et VBA Excel

  1. #1
    Membre confirmé
    Inscrit en
    Juin 2007
    Messages
    147
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 147
    Par défaut Selection d'une selection dans un filtre
    Alors me voici encore avec un petit problème lié aux filtres.

    Nous sommes dans une feuille filtrée avec des lignes masquées(qui n'appartiennent pas à la selection) et d'autres visibles(qui appartiennent à la selection).

    J'ai réussi à ne selectionner que les cellules filtrées avec "SpecialCells(xlCellTypeVisible)". Le problème c'est que dans cette selection je voudrais choisir les 50 derniers, et là ca bloque.

    J'ai essayé ".Offset(-50,0)" mais cela prend en compte les lignes masquées, même le ".row - 50", mais cela me donne le numéro de ligne de 50 de moins mais avec les lignes masquées prises en compte.

    En fait, je voudrais avoir le numéro de ligne de la 50ème opération en partant de la fin et ensuite cacher les cellules du dessus.

    Comment puis-je procéder ?

  2. #2
    Membre émérite

    Profil pro
    Inscrit en
    Mai 2007
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 514
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    Sub Afficher50Derniers()
        Dim xFilt As Range, xAll As Range, i As Long, j As Long
        Set xAll = ActiveSheet.AutoFilter.Range
        Set xFilt = xAll.Columns(1).SpecialCells(xlCellTypeVisible)
        For i = xAll.Cells(xAll.Cells.Count).Row To 1 Step -1
            If Not Intersect(xAll.Cells(i, 1), xFilt) Is Nothing Then
                j = j + 1
                If j = 50 Then Exit For
            End If
        Next
        MsgBox xAll.Cells(i, 1).Row
    End Sub
    La msgbox te renvoie le numero de ligne du 50e enregistrement affiché en partant de la fin.

    Cordialement,

    Tirex28/

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

Discussions similaires

  1. selection d'une case dans un formulaire
    Par salsero1 dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 02/05/2007, 17h39
  2. Réponses: 4
    Dernier message: 17/01/2007, 18h52
  3. [VBA-E] Selection d'une liste dans Excel
    Par GI_GI dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 13/01/2007, 02h05
  4. selection d'une ligne dans un tableau en html
    Par jehlg dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 08/02/2006, 23h08
  5. Selection d'une valeur dans une autre table
    Par beurnoir dans le forum Access
    Réponses: 1
    Dernier message: 13/10/2005, 12h02

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