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 ligne ne marche plus [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2011
    Messages
    128
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 128
    Par défaut suppression de ligne ne marche plus
    Bonjour à tous,
    j'ai un code qui marchait la semaine dernière et aujourd'hui, lundi... j'arrive pas à comprendre pourquoi il ne veut plus marcher...
    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    Option Explicit
     
     Public Sh As Worksheet
    Public i As Integer, Num_Fact As String
    Public np As Integer, Nc As Integer
    Public Rnp As Range, Plag As Range
     '---------------------------------------------------------Créer un nouveau devis vierge
     Sub Nouveau_Devis()
     
     Num_Fact = Range("C10").Value
     
     
    Application.DisplayAlerts = False
    For Each Sh In ThisWorkbook.Worksheets
        If InStr(Sh.Name, "Détail") > 0 Then
            Sh.Delete
     
        End If
    Next Sh
    Worksheets("Devis").Protect userinterfaceonly:=True
     
     Sheets("Devis").Activate
     
      Set Plag = Range("A23:A150")
     
     For Each Rnp In Plag
        If Rnp.Value = "Pied" Then ' il ne trouve pas la bonne cellule visiblement
        np = Rnp.Row 'il met np = 0 ? 
        Nc = np - 1
      End If
    Next
     
     
      Range("F19").Value = "SDV-" & Year(Date) & "-" & Month(Date) & Day(Date) & "-" & Format(Num_Fact + 1, "0")
     Range("L5").Value = Date
     Range("A24:A27").ClearContents
     Range("C24:G27").ClearContents
     
       For i = Nc To 28 Step -1
            Cells(i, 1).EntireRow.Delete
        Next
     
    Range("K13").Select
     
     End Sub
    Si quelqu'un comprend et m'explique je lui serai infiniment reconnaissant.

  2. #2
    Expert confirmé Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 756
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 756
    Par défaut
    Bonjour,

    Lance ton code debugage "pas à pas" et vérifie si toutes les conditions sont ok pour la suppression

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    For i = Nc To 28 Step -1
       Cells(i, 1).EntireRow.Delete
    Next
    Quelle est la valeur de i au démarrage de cette boucle?

  3. #3
    Membre Expert
    Homme Profil pro
    Retraité
    Inscrit en
    Avril 2011
    Messages
    1 858
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Avril 2011
    Messages : 1 858
    Par défaut
    Bonjour,

    Il faut que tu indiques la feuille concernée lorsque tu utilises Range.
    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    Option Explicit
    Public Sh As Worksheet
    Public i As Integer, Num_Fact As String
    Public np As Integer, Nc As Integer
    Public Rnp As Range, Plag As Range
     '---------------------------------------------------------Créer un nouveau devis vierge
    Sub Nouveau_Devis()
        Num_Fact = Worksheets("Feuil2").Range("C10").Value 'A ADAPTER
        Application.DisplayAlerts = False
        For Each Sh In ThisWorkbook.Worksheets
            If InStr(Sh.Name, "Détail") > 0 Then
                Sh.Delete
            End If
        Next Sh
        Worksheets("Devis").Protect userinterfaceonly:=True
        With Worksheets("Devis")
            Set Plag = .Range("A23:A150")
            For Each Rnp In Plag
                If Rnp.Value = "Pied" Then
                    np = Rnp.Row
                    Nc = np - 1
                End If
            Next
            .Range("F19").Value = "SDV-" & Year(Date) & "-" & Month(Date) & Day(Date) & "-" & Format(Num_Fact + 1, "0")
            .Range("L5").Value = Date
            .Range("A24:A27").ClearContents
            .Range("C24:G27").ClearContents
            For i = Nc To 28 Step -1
                Cells(i, 1).EntireRow.Delete
            Next
            .Range("K13").Select
        End With
    End Sub
    Cordialement.

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2011
    Messages
    128
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 128
    Par défaut
    ok merci pour vos réponses
    j'ai changé "pied" par "pieddepage" dans le code et dans le classeur ça a suffit ...

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

Discussions similaires

  1. Suppression des lignes qui n'ont pas la plus grande valeur
    Par Oberown dans le forum Développement
    Réponses: 5
    Dernier message: 21/12/2012, 17h40
  2. Réponses: 5
    Dernier message: 15/02/2008, 12h28
  3. ma fonction marche plus sur le serveur...
    Par CDRIK dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 18/10/2004, 05h24
  4. Réponses: 4
    Dernier message: 02/07/2004, 20h14
  5. [VB.NET] Suppression de ligne dans un DataTable
    Par seemax dans le forum Windows Forms
    Réponses: 7
    Dernier message: 06/05/2004, 15h19

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