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 ligne selon valeur présente dans une cellule


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Février 2017
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Chargé d'affaire
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2017
    Messages : 12
    Par défaut Suppression ligne selon valeur présente dans une cellule
    Bonjour à tous,

    Dans le cadre de mon job je dois vérifier des données de catalogue produits.
    Afin de m'aider dans cette tache j'ai réalisé un fichier avec des macros pour automatiser les vérifications.

    Je bloque cependant sur un problème. J'ai récupéré une macro qui permet de supprimer totalement une ligne si dans la cellule X de la colonne Y la valeur est vrai.
    Malheureusement cette macro ne fonctionne plus (alors qu'elle fonctionnait sur l'autre classeur).

    J'aimerai comprendre le problème et surtout réussir à faire fonctionner cette macro.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    Sub Suppression_Id_Variant()
    Dim MyRange As Range
    Dim L As Long
        Set MyRange = ActiveSheet.Range("A1").CurrentRegion
        For L = MyRange.Rows.Count To 1 Step -1
     
            If MyRange(L, 57).Value = True Then MyRange(L, 57).EntireRow.Delete
     
        Next
    End Sub


    Dans le fichier Joint il s'agit des Macros Suppression_doublons et de Suppression_Id_Variant.

    Merci d'avance de votre aide.

    Aurélien
    Fichiers attachés Fichiers attachés

  2. #2
    Membre Expert
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 817
    Billets dans le blog
    10
    Par défaut
    Bonjour,

    Que vaut MyRange lors de l'exécution de ta macro?

    Test comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub Test()
    Dim MyRange As Range
        Set MyRange = ActiveSheet.Range("A1").CurrentRegion
        MsgBox MyRange.Address
    End Sub

  3. #3
    Membre averti
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Février 2017
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Chargé d'affaire
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2017
    Messages : 12
    Par défaut
    Bonjour pijaku,

    La réponse reçu est $A$1:$E$1

    Je pense qu'il y a un souci...

    Comment je peux définir cette plage MyRange ??

    Merci

    Aurélien

  4. #4
    Membre averti
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Février 2017
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Chargé d'affaire
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2017
    Messages : 12
    Par défaut
    J'ai modifié la Range A1 en A4 et cela fonctionne. Merci beaucoup pour la piste de My range !!

    Bonne journée

    Aurélien

  5. #5
    Membre Expert
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 817
    Billets dans le blog
    10
    Par défaut
    Essaye ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub Test2()
    Dim MyRange As Range
        Set MyRange = ActiveSheet.UsedRange
        MsgBox MyRange.Address
    End Sub
    Sinon ceci (adapter les 2 constantes, bien entendu) :
    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 Test3()
    Dim DL As Long, MyRange As Range
    Const PREMCELLULE As String = "A2"
    Const DERNCOLONNE As String = "AB"
     
       DL = derlig_reelle(Worksheets("Feuil1").Columns(1))
       Set MyRange = Range(PREMCELLULE & ":" & DERNCOLONNE & DL)
        MsgBox MyRange.Address
    End Sub
     
    Private Function derlig_reelle(plage As Range) As Long
       'cas d'absence de données dans la plage à traiter :
       If WorksheetFunction.CountA(plage) = 0 Then derlig_reelle = 1: Exit Function
       'dans tous les autres cas :
       derlig_reelle = plage.Find("*", , , , , xlPrevious).Row
    End Function

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

Discussions similaires

  1. [VBA] fonction qui donne la valeur présente dans une table
    Par zanou666 dans le forum VBA Access
    Réponses: 7
    Dernier message: 25/09/2007, 17h33
  2. Réponses: 4
    Dernier message: 05/03/2007, 14h53
  3. Donner à une feuille la valeur contenue dans une cellule ?
    Par emilie_pons_2005 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 11/09/2006, 12h32
  4. Réponses: 3
    Dernier message: 13/06/2006, 16h36
  5. calcul de valeurs présentes dans une liste de résultat
    Par Makaveli33 dans le forum Access
    Réponses: 8
    Dernier message: 15/05/2006, 19h03

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