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 :

Ne garder que le dernier bloc [XL-2003]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de Vadorblanc
    Profil pro
    Inscrit en
    Février 2008
    Messages
    309
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 309
    Par défaut Ne garder que le dernier bloc
    Bonjour
    Je souhaite supprimer toutes les lignes différentes de la dernière ligne non vide de la valeur en colonne A
    Exemple:
    j'ai en colonne A "janvier" avec une variable de lignes
    j'ai en collonne A "février" avec une variable de lignes
    j'ai en colonne A "mars" avec une variable de ligne, etc...
    et je voudrais garder que le dernier bloc de lignes contenant "mars" qui est le bloc le plus bas du fichier, sachant que le dernier bloc puisse être un mois de janvier à décembre tout dépend de la date d'extraction en cours d'année.
    Donc supprimer toutes les lignes en partant du bas du fichier qui sont différentes de la valeur en colonne A de la dernière ligne.
    Ce code ne me supprime que les lignes contenant "janvier"
    Il me faudrait supprimer les lignes
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If ActiveCell = <>A? Then
    Merci

    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
    Sub Supprime()
     
    Application.ScreenUpdating = False
    With Sheets("Base")
     
    Range("A65536").End(xlUp).Select
    Do While ActiveCell.Row > Range("A1").Row
    If ActiveCell = "janvier" Then
    ActiveCell.EntireRow.Delete
    End If
    ActiveCell.Offset(-1, 0).Select
    Loop
    If ActiveCell = "A" Then
    ActiveCell.EntireRow.Delete
    End If
    End With
    End Sub

  2. #2
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Dim Lastlig As Long
     
    Application.ScreenUpdating = False
    With Sheets("Base")
         .AutoFilterMode = False
         Lastlig = .Cells(.Rows.Count, 1).End(xlUp).Row
         .Range("A1:A" & Lastlig).AutoFilter field:=1, Criteria1:="<>" & .Range("A" & Lastlig).Value
         If .Range("A1:A" & Lastlig).SpecialCells(xlCellTypeVisible).Count > 1 Then .Range("A2:A" & Lastlig).SpecialCells(xlCellTypeVisible).EntireRow.Delete
         .AutoFilterMode = False
    End With

  3. #3
    Membre éprouvé Avatar de Vadorblanc
    Profil pro
    Inscrit en
    Février 2008
    Messages
    309
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 309
    Par défaut
    Bonjour mercatog
    C'est génial, je mets bien de côté toutes les boucles que tu m'as déjà donné...en essayant toujours de les comprendres...
    Un grand Merci à toi
    Bien cordialement

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 24/06/2011, 01h50
  2. Réponses: 8
    Dernier message: 26/08/2010, 17h12
  3. Ne garder que le plus grand
    Par mobscene dans le forum Langage
    Réponses: 30
    Dernier message: 23/12/2005, 01h23
  4. selection avec group by mais ne garder que ...
    Par Larson dans le forum Langage SQL
    Réponses: 13
    Dernier message: 22/06/2005, 17h23
  5. [Oracle 8i] ne garder que certains enregistrements (COUNT ?)
    Par delphim dans le forum Langage SQL
    Réponses: 13
    Dernier message: 23/02/2005, 14h30

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