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 :

Macro efface ligne


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juin 2016
    Messages
    44
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2016
    Messages : 44
    Par défaut Macro efface ligne
    Bonjour,

    j'ai une macro qui fonctionne mais qui prend du temps. Je voudrais savoir si je pouvais la simplifier pour aller plus vite.
    La macro a pour but de vérifier si en colonne on a 0, on supprime la ligne.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Sub efface_zero()
    Dim n&, i&
     
    n = Cells(420, 2).End(3).Row
    For i = n To 1 Step -1
            If Cells(i, 2) = 0 Then Rows(i).Delete
    Next i
     
    End Sub
    Merci de votre aide.

  2. #2
    Membre émérite

    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    652
    Détails du profil
    Informations personnelles :
    Localisation : France, Ardèche (Rhône Alpes)

    Informations forums :
    Inscription : Octobre 2006
    Messages : 652
    Par défaut
    Bonjour,

    déjà, en début de macro ,écris

    application.screenupdating=false

    qui fige le défilement de l'écran: confort et rapidité
    à installer sur pratiquement toutes les macros

    edit 09:29h
    bien que sur 420 lignes la différence est peanuts
    cette macro ne boucle que sur le nombre de 0 dans la colonne A ("A" pour l'exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Option Explicit
    '-----------------------
    Sub supprimer_zéro()
    Dim Nbre As Integer, Cptr As Integer, Lig As Integer
        Application.ScreenUpdating = False
        Nbre = Application.CountIf(Columns("A"), 0)
        For Cptr = 1 To Nbre
            Lig = Columns("A").Find(0, Range("A1"), xlValues).Row
            Rows(Lig).Delete
        Next
    End Sub

  3. #3
    Membre averti
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juin 2016
    Messages
    44
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2016
    Messages : 44
    Par défaut
    merci

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

Discussions similaires

  1. Macro pour effacer lignes
    Par didjo dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 06/11/2008, 16h43
  2. [WD8]effacer ligne d'une liste
    Par fanant dans le forum WinDev
    Réponses: 5
    Dernier message: 16/04/2007, 10h30
  3. [VBA-E]Efface ligne ne correspondant pas a mon Secteur
    Par baptbapt dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 31/08/2006, 09h40
  4. [VBA-E]Effacer ligne si une autre ligne est identique
    Par baptbapt dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 03/08/2006, 13h41
  5. effacer ligne arriere d'une GlutSphere
    Par killerjeff dans le forum OpenGL
    Réponses: 7
    Dernier message: 20/12/2005, 10h00

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