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 :

Supprimer ligne par macro


Sujet :

Macros et VBA Excel

  1. #1
    Membre régulier Avatar de a.dequidt
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    144
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 144
    Points : 77
    Points
    77
    Par défaut [VBA-E] Help! Supprimer ligne par macro
    bonjour,

    dans mon fichier excel, j'ai un tableau de devis, comprenant
    dans la colonne A la quantité,
    en B la référence du produit,
    en I le prix unitaire
    en K le code produit,
    en S la marque du produit.


    A l'ouverture du ficher, la colonne S n'est pas vide!

    Je cherche a faire une macro qui lorsqu'il n'y a pas de référence d'entrée, la ligne se supprime!

    Dans ma macro actuelle, je fais une recherche pour trouver la 1ere ligne de me tableau et la derniere
    >> ça c'est bon il sauvegarde les bonnes valeurs
    Ensuite je cherche si les lignes qui ont une marque (colonne S non vide) mais qui n'ont pas de référence,
    Si j'en trouve une, je l'efface!

    voici mon code actuel


    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
    18
    19
    20
    Sub effacer_ligne()
     
        For i = 1 To 100
            If Range("A" & i).Value = "Qté" Then
                ligne_min = i + 1
            End If
     
            If Range("H" & i).Value = "Total :" Then
                ligne_max = i - 2
            End If
     
         Next i
     
        For i = ligne_min To ligne_max
            If Range("B" & i).Value = "" And Range("S" & i).Value <> "" Then
                Rows(i).Delete Shift:=xlShiftUp
            End If
        Next i
     
    End Sub
    Actuellement quand je lance ma macro, elle s'exécute correctement mais elle ne supprime pas toutes les lignes vides.
    Sur les 6 linges de mon tableau si une seule ligne est remplie, sur les 5 lignes a supprimer seulement 3 ont étées supprimées
    Aurore //Gold Fish Memory Girl

  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
    Je te propose de regarder ici, tu as plusieurs méthodes, à toi de choisir

  3. #3
    Membre régulier Avatar de a.dequidt
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    144
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 144
    Points : 77
    Points
    77
    Par défaut
    Hello les p'tits loups

    Ca fait 48h que je voulais pas embéter avec mes questions a 2 balles
    Alors comme vous me manquez, je reviens a la charge!
    Je cherche a faire une macro de suppression de ligne
    l'erreur se produit sur mon test de "if" (erreur '1004')


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
        b=1
        ligne_min = Range("O" & b).Value
        ligne_max = Range("P" & b).Value
        For i = ligne_max To ligne_min Step -1
            If Cells(i, 19).Value = "" Then
                Rows(i).delete Shift:=xlShiftUp
                i = i - 1
                ligne_max = ligne_max - 1
            End If
        Next i

    Bisous bisous

    Aurore
    Aurore //Gold Fish Memory Girl

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Août 2007
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2007
    Messages : 35
    Points : 39
    Points
    39
    Par défaut
    Chez moi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    b=1                                                     'b= 1
    ligne_min = Range("O" & b).Value
    ligne_max = Range("P" & b).Value              'ligne_max = Empty (normal, Range("P" & b) est vide
    For i = ligne_max To ligne_min Step -1       'i = 0 (conversion automatique, du coup il va chercher une case qui n'existe pas et j'ai ton message d'erreur)
    If Cells(i, 19).Value = "" Then
    Rows(i).delete Shift:=xlShiftUp
    i = i - 1
    ligne_max = ligne_max - 1
    End If
    Next i
    ps : si je remplis O1 et P1 avec des valeurs plus grandes que 1, ca marche correctement.

  5. #5
    Membre régulier Avatar de a.dequidt
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    144
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 144
    Points : 77
    Points
    77
    Par défaut
    Ba pas chez moi :'(
    Aurore //Gold Fish Memory Girl

  6. #6
    Inactif  
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    2 054
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 054
    Points : 2 416
    Points
    2 416
    Par défaut
    Citation Envoyé par a.dequidt Voir le message

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
        b=1
        ligne_min = Range("O" & b).Value
        ligne_max = Range("P" & b).Value
        For i = ligne_max To ligne_min Step -1
           if i>0 then
               If Cells(i, 19).Value = "" Then
                   Rows(i).delete Shift:=xlShiftUp
                   i = i - 1
                   ligne_max = ligne_max - 1
               End If
            end if
        Next i
    Bonjour,
    J'ai pas testé mais à mon avis c'est quand i =0 d'ou la petite modif sur ton code, essaye la..
    A+
    EDIT:
    Variante...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
       Rows(i).delete Shift:=xlShiftUp
       if i=1 then exit for

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

Discussions similaires

  1. [OpenOffice][Tableur] Supprimer une ligne par macro
    Par elodiemart dans le forum OpenOffice & LibreOffice
    Réponses: 2
    Dernier message: 19/07/2013, 10h30
  2. [XL-2003] Supprimer MFC par macro
    Par Cocotte278 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 21/09/2011, 16h29
  3. [XL-MAC 2011] supprimer ligne par rapport a un combobox
    Par sebing dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 30/01/2011, 09h20
  4. supprimer ligne avec macro textbox
    Par lilou86 dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 30/04/2008, 14h07
  5. suppression de ligne par macro
    Par stefano dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/02/2008, 14h41

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