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 :

Masquer lignes 3 conditions [XL-2010]


Sujet :

Macros et VBA Excel

  1. #1
    Membre régulier
    Inscrit en
    Avril 2011
    Messages
    465
    Détails du profil
    Informations forums :
    Inscription : Avril 2011
    Messages : 465
    Points : 97
    Points
    97
    Par défaut Masquer lignes 3 conditions
    Bonjour,

    Ce problème a déjà été évoqué plusieurs fois mais je n'y comprends rien.

    J'aimerai masquer les lignes d'un fichier excel si 3 conditions sont respectées:

    Il faut masquer la ligne si dans une même ligne colonne B<>"", colonne C="" et colonne D="" sur la plage B5:D150

    J'ai tenté un bout de code qui ne marche pas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub masquer()
     
    Worksheets("Sheet2").Range("B5:D130").Select
        For Each o In Selection
            If o.Value = "" Then
                o.EntireRow.Hidden = True
            End If
    Next
     
    End Sub
    J'ai directement une erreur sur Worksheets("Sheet2").Range("B5:D130").Select.
    J'ai voulu tenter une boucle imbriqué pour la condition B<>"" mais je n'y arrive pas, ça fait des heures que je cherche mais je ne trouve pas....

    Merci d'avance pour votre aide!

  2. #2
    Expert éminent
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Points : 6 871
    Points
    6 871
    Par défaut
    Bonjour,

    Teste ce qui suit :
    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
     
    Sub masquer()
     
        Dim Plage As Range
        Dim Ligne As Range
     
        Set Plage = Worksheets("Sheet2").Range("B5:D130")
     
        'B<>"", colonne C="" et colonne D=""
        For Each Ligne In Plage.Rows
     
            If Ligne.Cells(1).Value <> "" _
                And Ligne.Cells(2).Value = "" _
                And Ligne.Cells(3).Value = "" Then Ligne.EntireRow.Hidden = True
     
        Next Ligne
     
    End Sub
    Hervé.

  3. #3
    Membre régulier
    Inscrit en
    Avril 2011
    Messages
    465
    Détails du profil
    Informations forums :
    Inscription : Avril 2011
    Messages : 465
    Points : 97
    Points
    97
    Par défaut
    Bonjour Hervé,
    Merci pour ta réponse ça marche parfaitement.
    J'ai vraiment du mal en Vba, j'arrive à comprendre les codes mais impossible de les écrire moi même...

    Encore merci pour ton aide Hervé !

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

Discussions similaires

  1. Macro afficher masquer ligne condition Vlookup
    Par m.hamzaoui dans le forum Général VBA
    Réponses: 3
    Dernier message: 01/06/2014, 20h20
  2. Masquer lignes avec conditions dans tableau
    Par logoden dans le forum Débuter
    Réponses: 2
    Dernier message: 28/02/2012, 12h18
  3. [CR 2008] tableau croisé dynamique(masquer une ligne sous condition)
    Par futurist dans le forum SAP Crystal Reports
    Réponses: 1
    Dernier message: 29/09/2010, 14h57
  4. Masquer des lignes sous condition
    Par linousxm dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 23/05/2010, 13h19
  5. Masquer des lignes sur condition
    Par marc56 dans le forum Macros et VBA Excel
    Réponses: 25
    Dernier message: 06/03/2008, 02h11

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