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 :

Suppression de lignes [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
    Inscrit en
    Janvier 2010
    Messages
    23
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 23
    Par défaut Suppression de lignes
    Bonjour à tous, je voudrais supprimer les lignes vides de mon fichier. Il se trouve que quand j'ai plus d'une ligne vide qui se visent, mon code ne prend en compte qu'une ligne sur deux.
    Il faudrait (il me semble) que je démarre par la ligne du bas et que je remonte dans ma sélection.
    Mais je ne sais pas comment faire

    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
    Sub supligne()
     
    Dim derlign As Long, plage As Range
    Dim numligne As Long
    derlign = Sheets("Table de travail").Range("A12000").End(xlUp).Row
    Set plage = Sheets("Table de travail").Range("A7" & ":A" & derlign)
    With Sheets("Table de travail")
    For i = 5 To dernligne
    numlign = c.Row
    If Cells(i, 17) = "" Then
        Rows(i).Delete Shift:=xlShiftDown
     
              End If
              Next i
    End With
    End Sub
    Merci pour votre aide
    Cordialement José

  2. #2
    Membre Expert Avatar de laetitia
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    1 281
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 281
    Par défaut
    bonjour jose_67 le forum essai comme cela

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sub es()
       Sheets("Table de travail").[q5:q12000].SpecialCells(xlCellTypeBlanks).Rows.Delete
    End Sub

  3. #3
    Expert confirmé
    Avatar de Qwazerty
    Homme Profil pro
    La très haute tension :D
    Inscrit en
    Avril 2002
    Messages
    4 128
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : La très haute tension :D
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 128
    Par défaut
    Salut
    Coucou Leti

    Je n'ai pas essayé la solution de Laeticia, j'ai d'ailleurs failli la rater puisque qu'elle a répondu après que j'ai mis a jour la page du Fofo

    Bref pour inverser une boucle for
    il faut mettre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For i = dernligne to 5 step -1
    voila a ++
    Qwaz

    MagicQwaz := Harry Potter la baguette en moins
    Le monde dans lequel on vit
    Ma page perso DVP
    Dernier et Seul Tutoriel : VBA & Internet Explorer
    Dernière contribution : Lien Tableau Structuré et UserForm
    L'utilisation de l’éditeur de message

  4. #4
    Membre Expert Avatar de laetitia
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    1 281
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 281
    Par défaut
    re,coucou Qwaz en partant de son code!!

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub es()
      Dim i As Integer
        Application.ScreenUpdating = False
        With Sheets("Table de travail")
         For i = .Range("q12000").End(xlUp).Row To 5 Step -1
         If .Cells(i, 17) = "" Then .Rows(i).Delete
      Next i: End With
    End Sub

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 48
    Par défaut
    Salut laetitia, Qwazerty, le forum

    Je crois qu'il veut effacer la ligne en entier et en essayant le premier bout de code de laetitia ça n'effaçait que des cellules

    J'ai essayé de trouver une solution mais je ne suis pas encore assez au point... même je n'en suis pas loin je pense !


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub es()
    Dim derlign As Integer
    Dim i As Integer
    Do Until Sheets("Table de travail").Range("q12000").SpecialCells(xlCellTypeBlanks).Row = Sheets("Table de travail").Range("q12000").End(xlUp).Offset(1).Row
    derlign = Sheets("Table de travail").Range("q12000").SpecialCells(xlCellTypeBlanks).Row
    Range("A" & derlign & "").EntireRow.Delete
    Loop
    End Sub
    ça pause un problème par contre si les lignes à effacer sont contiguës avec la dernière.

    C'est pas parfait surement, je m'exerce

  6. #6
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    Il semble bien que votre problème soit que des lignes ne contenant aucune données ne soient pas reconnues comme des lignes vides (pour diverses raisons, par exemple formatage de colonnes ou de plage). Or lorsque la ligne est supprimée, la suppression n'est prise en compte que lorsque le fichier est enregistré.

    Autrement dit, si c'est bien ce cas, lorsque vous supprimez la 1ère ligne vide et que vous utilisez ensuite :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    derlign = Sheets("Table de travail").Range("q12000").SpecialCells(xlCellTypeBlanks).Row
    c'est toujours la même "dernière ligne qui est trouvée".

    A priori, je pense que les solutions de Laetitia ou de Quazerty devraient fonctionner, mais sûrement pas la vôtre.

    Et ne pas oublier d'enregistrer votre fichier avant de faire autre chose.

    D'autre part vous avez indiqué la ligne N° 12000 comme étant la dernière ligne : c'est bien parce que si vous appuyez sur "Ctrl + Fin" le curseur se trouve en ligne 12000 ?

    Sinon vous pouvez utiliser :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    derlign = Range("Q65536").End(xlUp).Row
    mais bien évidemment avant la boucle et non pas à l'intérieur de la boucle.

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

Discussions similaires

  1. [Excel - VBA] Problème de suppression de lignes...
    Par beholder2 dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 28/01/2005, 17h27
  2. Suppression de lignes dans un fichier
    Par bubu dans le forum Linux
    Réponses: 2
    Dernier message: 13/01/2005, 10h36
  3. Dbgrid : Comment interdire Suppression de Ligne
    Par Francis dans le forum Bases de données
    Réponses: 3
    Dernier message: 28/11/2004, 08h31
  4. Réponses: 4
    Dernier message: 02/07/2004, 19h14
  5. [VB.NET] Suppression de ligne dans un DataTable
    Par seemax dans le forum Windows Forms
    Réponses: 7
    Dernier message: 06/05/2004, 14h19

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