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 :

Simplifier les condition d'un If [XL-2016]


Sujet :

Macros et VBA Excel

  1. #21
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 811
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 811
    Points : 28 702
    Points
    28 702
    Billets dans le blog
    53
    Par défaut
    Bonsoir,
    Une solution avec EVALUATE

    S'il faut tester si les cellules d'une même ligne sont remplies
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If Evaluate("=COUNTA(A7:J7) = COLUMNS(A7:J7)") Then MsgBox "Toutes remplies"
    S'il fallait tester des cellules remplies sur plusieurs lignes et plusieurs colonnes
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If Evaluate("=COUNTA(A7:J8) = COLUMNS(A7:J8) * ROWS(A7:J8)") Then MsgBox "Toutes remplies"
    et aussi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If Application.CountA(Range("A7:J7")) = Range("A7:J7").Count Then MsgBox "Toutes remplies"
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  2. #22
    Expert éminent sénior
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Points : 18 677
    Points
    18 677
    Par défaut
    Bonjour !

    Citation Envoyé par Cap'taineSamSam Voir le message
    Je souhaite tester si toutes les cellules d'une plage ("A7:J7") sont remplies.
    Philippe m'a devancé alors voici une variante avec Evaluate :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Sub Demo1()
        V = Filter([IF(A7:J7="",ADDRESS(7,COLUMN(A7:J7),4))], False, False)
        If UBound(V) > -1 Then MsgBox "Manque saisie dans " & Join(V, ", "), vbExclamation, " Contrôle :"
    End Sub
    ___________________________________________________________________________________________________________

         Merci de cliquer sur en bas à droite de chaque message ayant aidé puis sur pour clore cette discussion …

    ___________________________________________________________________________________________________________
    Je suis Paris, Egypte, Stockholm, London, Istanbul, Berlin, Nice, Bruxelles, Charlie, …
    C'est parce que la vitesse de la lumière est plus rapide que celle du son que tant de gens paressent brillants avant d'avoir l'air con ! (Thomas Boishardy)

  3. #23
    Membre émérite
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Nord (Nord Pas de Calais)

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

    Une fonction personnalisée qui ne tient pas compte des cellules vides contenant une formule :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Function Toutes_Remplies(Plage As Range) As Boolean
        Toutes_Remplies = (Application.CountA(Plage) = Plage.Cells.Count)
    End Function
    EDIT :
    oups, désolé...
    Je n'avais pas lu la dernière proposition de philippe...
    Cordialement,
    Franck

  4. #24
    Membre extrêmement actif
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 82
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Points : 12 422
    Points
    12 422
    Par défaut
    Bonjour Franck
    Oui.
    Attention toutefois aux surprises résultant de la conjugaison :
    - de l'affectation dynamique d'une valeur VBEmpty (cela va te rappeler une discussion)
    - de la configuration des options Excel

    Amitiés
    Je n'accepte pas de demande d' "amitié" individuelle. Tout développeur est pour moi un ami.
    Je n'ouvre AUCUN classeur tiers (avec ou sans macro ******). Ne m'en proposez donc pas .

    ****** : Non, non ... un classeur .xlsx ne "peut" par exemple et entre autres pas contenir un activex (de surcroît invisible) , "bien sûr" ...

    Il est illusoire de penser que l'on saurait exprimer valablement et précisément en un langage (rigide) de développement ce que l'on peine à exprimer dans le langage naturel, bien plus souple.

  5. #25
    Membre extrêmement actif Avatar de mjpmjp
    Homme Profil pro
    Retraité
    Inscrit en
    Avril 2012
    Messages
    1 133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hautes Alpes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Santé

    Informations forums :
    Inscription : Avril 2012
    Messages : 1 133
    Points : 1 441
    Points
    1 441
    Par défaut
    bonjour,
    @unparia
    Question (car solution en dépendant) : ces cellules ne contiennent-elles QUE des constantes ou peuvent-elles contenir également des résultats de formules ?
    c'est une bonne question
    @Cap'taineSamSam
    J'ai pas le fichier sous les yeux (il est au boulot) mais si je me souviens bien:
    c'est la case C7 = Si (D7 = "*"; "h"; "")
    la formule elle même n'est pas comptée par "len" et le "" arrive à point
    Len([a7] & [b7] & [c7] & [d7] & [e7] & [f7] & [g7] & [h7] & [i7] & [J7])
    comment "racourcir" ...disait ABRAS!!!....

    @+JP
    Caractéristiques (WEB) phpMyAdmin 4-74 , PHP 5-631 , Apache 2-427 , MySQL 5-719
    Présentation NAS DS-3615xs + 20Go , DSM 6.1.6-15266 Up1 , 12 * WD 4To WD4000F9YZ (10 raid 6+ )+(2 raid 1+) , LinkSys comutateur-switch lgs528p-eu , Onduleur UPS 720W Power Boxx Lcd (4*UPS + 4*MOD)
    Mes contributions (EXCEL) Form GRAPHIQUE: Gestion des boutons , Liste Onglet dynamique...GESTION de FILM

  6. #26
    Membre émérite
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 814
    Points : 2 949
    Points
    2 949
    Billets dans le blog
    10
    Par défaut
    Bonjour Jacques,
    Citation Envoyé par unparia Voir le message
    Attention toutefois aux surprises résultant de la conjugaison :
    - de l'affectation dynamique d'une valeur VBEmpty (cela va te rappeler une discussion)
    - de la configuration des options Excel
    VbEmpty Ok. En effet, cela me rappelle quelque chose
    Mais quid de la configuration des options Excel?
    Cordialement,
    Franck

  7. #27
    Membre extrêmement actif
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 82
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Points : 12 422
    Points
    12 422
    Par défaut
    Ah ..
    1) (aide vba) :
    WorksheetFunction.CountA, méthode
    Compte le nombre de cellules non vides, ainsi que les valeurs dans la liste d'arguments.
    ....
    Une valeur peut être n'importe quel type d'informations, notamment des valeurs d'erreur et du texte vide ("").
    (clair)
    2) les options de Exel (mais moins important) :
    On peut configurer de sorte à ce que l'affectation de vbEmpty mette un 0 et non ""
    Observe que l'affectation de "", mettrait un "" (mais qui ne serait pas un VIDE non plus)
    Seule l'affectation de VBNullString ne compromettrait pas ton code

    Rigolo qu'on en ait parlé il y a peu, non ?

    Amitiés
    Je n'accepte pas de demande d' "amitié" individuelle. Tout développeur est pour moi un ami.
    Je n'ouvre AUCUN classeur tiers (avec ou sans macro ******). Ne m'en proposez donc pas .

    ****** : Non, non ... un classeur .xlsx ne "peut" par exemple et entre autres pas contenir un activex (de surcroît invisible) , "bien sûr" ...

    Il est illusoire de penser que l'on saurait exprimer valablement et précisément en un langage (rigide) de développement ce que l'on peine à exprimer dans le langage naturel, bien plus souple.

  8. #28
    Membre émérite
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 814
    Points : 2 949
    Points
    2 949
    Billets dans le blog
    10
    Par défaut
    Citation Envoyé par unparia Voir le message
    1) (aide vba) :
    WorksheetFunction.CountA, méthode
    Compte le nombre de cellules non vides, ainsi que les valeurs dans la liste d'arguments.
    ....
    Une valeur peut être n'importe quel type d'informations, notamment des valeurs d'erreur et du texte vide ("").
    (clair)
    2) les options de Exel (mais moins important) :
    On peut configurer de sorte à ce que l'affectation de vbEmpty mette un 0 et non ""
    Observe que l'affectation de "", mettrait un "" (mais qui ne serait pas un VIDE non plus)
    Seule l'affectation de VBNullString ne compromettrait pas ton code
    Il faut donc s'entendre sur ce que l'on appelle "vide".
    Dans une cellule : ="" peut apparaître vide (selon les options excel en effet), mais ne l'est pas.
    Tu as raison.
    Cordialement,
    Franck

  9. #29
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2017
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2017
    Messages : 28
    Points : 13
    Points
    13
    Par défaut
    Bonjour à tous et merci pour toutes vos réponses!!

    Après quelques tests pour voir quel code correspondait le mieux à mon besoin, j'ai choisi d'utiliser:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     If Application.CountA(Range("A7:J7")) = Range("A7:J7").Count Then
    Merci encore à tous pour votre participation

    Sam

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. Syntaxe pour les conditions
    Par Gabout dans le forum VBA Access
    Réponses: 2
    Dernier message: 06/05/2007, 12h27
  2. Réponses: 11
    Dernier message: 01/05/2007, 00h15
  3. Opérateur dans les conditions
    Par ez3kiel dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 19/03/2007, 14h53
  4. Les conditions dans Dreamweaver
    Par zeugzeug dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 06/01/2007, 12h48
  5. Réponses: 4
    Dernier message: 23/11/2006, 22h05

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