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 :

Aide avec .Value


Sujet :

Macros et VBA Excel

Vue hybride

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

    Informations forums :
    Inscription : Novembre 2011
    Messages : 160
    Par défaut Aide avec .Value
    Bonjour à tous,

    J'utilise la macro suivant qui efface les lignes d'un tableau lorsque la valeur de la colonne Y est vide.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub DELEMPTYpositif()
        Dim iRow As Long
        For iRow = Cells(Rows.Count, "Z").End(xlUp).Row To 15 Step -1
     
                 If Cells(iRow, "y").Value = "" Then
     
                Rows(iRow).Delete
            End If
        Next iRow
     
     
     
    End Sub
    J'aimerais que la ligne s'efface aussi lorsque la colonne = 1 et =BABY

    j'ecris le code comme cela :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If Cells(iRow, "y").Value = ""; "1"; "BABY"  Then
    mais cela ne marche pas,

    Pourriez vous m'aide?

    Merci beaucoup

  2. #2
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 176
    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 : 13 176
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    C'est tout à fait normal que cela ne fonctionne pas. Comme il y a plus d'une valeur à tester, il faut utiliser le Or
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub t1()
      If Cells(2, 7).Value = "Baby" Or Cells(2, 7).Value = 1 Or Cells(2, 7).Value = "toto" Then
         MsgBox "Oui"
      End If
    End Sub
    Attention que le test logique de If est sensible à la casse contrairement à la fonction SI d'excel, il est donc préférable d'imbriquer la valeur de la cellule dans la fonction LCase

    Personnellement, j'utiliserais le Select Case nettement plus lisible et plus simple à maintenir dans ce cas précis et comme cette instruction est également sensible à la casse
    Exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Sub t()
       Select Case LCase(Cells(2, 7).Value)
         Case "baby", 1, "toto"
           MsgBox "Oui"
         Case Else
       End Select
    End Sub
    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

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Novembre 2011
    Messages
    160
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2011
    Messages : 160
    Par défaut Merci
    Merci beaucoup,

    Quelle compétence !!
    Très bon été,

  4. #4
    Expert confirmé
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Billets dans le blog
    7
    Par défaut
    Bonjour à vous, bonjour au Forum,

    Salut Philippe

    Il y a sans doute un moyen d'éviter la gestion de la casse et, partant, l'utilisation des fonctions majuscules et minuscules.
    Celui-ci consiste à écrire en entête de module la déclaration

    Si en cellule A1, il est écrit
    "baby

    Le code

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Option Compare Text
     
    Sub essai()
    Debug.Print Feuil1.[A1]
    Debug.Print Feuil1.[A1] = "BaBy"
    End Sub
    retournera respectivement "baby" et Vrai.

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

Discussions similaires

  1. [ASA] J'ai besoin d'aide avec sybase et vb6 svp !!
    Par tibo830 dans le forum SQL Anywhere
    Réponses: 7
    Dernier message: 12/05/2006, 10h09
  2. [Struts] <logic:equal> pb avec value ?
    Par Pwill dans le forum Struts 1
    Réponses: 3
    Dernier message: 03/06/2005, 09h57
  3. effectuer une requete insert avec 'values' ET 'select'
    Par delaio dans le forum Bases de données
    Réponses: 4
    Dernier message: 15/08/2004, 19h05
  4. Réponses: 2
    Dernier message: 29/08/2003, 17h52
  5. Besoin d'aide avec postgresql sous windows NT
    Par Chihuahua dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 18/07/2003, 08h29

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