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 :

interior.colorindex et macro personnalisée


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 36
    Par défaut interior.colorindex et macro personnalisée
    Bonjour à tous,


    Je voudrais savoir s'il est possible de coder une fonction particulière qui renvoie biensur un résultat dans une cellule (sur tout une colonne - 1300 lignes) mais aussi qui colore cette cellule en fonction de la valeur qu'elle a calculée?

    J'ai essayé .colorindex dans ma function mais je pense que le fait que ce soit une fonction sur cette cellule, ça gèle les modifications. Est-ce possible? Pouvez-vous m'expliquer le principe?

    J'ai donc essayé de passer par l'évènement worksheet_selectionchange(Target...). Mais le problème c'est qu'a chaque changement, il cherche à colorer les cellules et du coup bloque le calcul des valeurs dans ces cellules (ma fonction personnalisée).

    Il ne me reste plus que la solution du bouton au dessus de la colonne à colorer et que le user clique à chaque fois. C'est pas top.

    Auriez vous une idée pour que ce soit automatisé?
    Autre question, pourquoi une function ne peut pas exécuter un changement de couleur? Est-ce ça le problème?

    Merci pour toutes vos aides.
    Je n'ai pas mis volontairement de code ici car il serait trop long je pense.
    Pris à part, ils fonctionnent bien. C'est l'association function et colorisation qui ne va pas.

  2. #2
    Membre Expert
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 567
    Détails du profil
    Informations personnelles :
    Âge : 62
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 567
    Par défaut
    tu peux essayer comme ça
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Public b As Range
    Function test(a, b)
    test = a * 2
    Range(b.Address).Interior.ColorIndex = 3
    End Function
    Sub je_teste()
    Set plage = Range("a1")
    plage.Value = test(4, plage)
    End Sub

  3. #3
    Membre Expert Avatar de wilfried_42
    Homme Profil pro
    Auto-entrepreneur
    Inscrit en
    Novembre 2006
    Messages
    1 427
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Auto-entrepreneur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 427
    Par défaut
    Bonjour Osygn44, alsimbad

    Quand tu modifies la valeur d'une cellule manuellement ou par macro, ça lance l'interruption : Worksheet_Change et non pas Worksheet_SelectionChange.

    Donc ta Macro Modifie tes valeurs qui provoquent l'interruption citée qui elle même modifie les couleurs...

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 36
    Par défaut
    Merci pour vos réponses.
    Cette nuit j'ai trouvé la solution.
    cependant, j'aimerais comprendre pourquoi une fonction ne peut pas faire interior.colorindex?
    pourquoi ont-ils bloqués cette possibilité dans excel?
    c'est vraiment dommage.

  5. #5
    Modérateur
    Avatar de AlainTech
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mai 2005
    Messages
    4 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2005
    Messages : 4 235
    Par défaut
    Une fonction, appelée dans la formule d'une cellule, ne peut modifier le contenu de la feuille.
    N'oubliez pas de cliquer sur quand vous avez obtenu ou trouvé vous-même la réponse à votre question.
    Si vous trouvez seul, pensez à poster votre solution. Elle peut servir à d'autres!
    Pensez aussi à voter pour les réponses qui vous ont aidés.
    ------------
    Je dois beaucoup de mes connaissances à mes erreurs!

  6. #6
    Membre Expert
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 567
    Détails du profil
    Informations personnelles :
    Âge : 62
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 567
    Par défaut
    Citation Envoyé par oxygn44
    cependant, j'aimerais comprendre pourquoi une fonction ne peut pas faire interior.colorindex?
    es-ce que tu a réelement essayé la fonction que je t'ai envoyé?

Discussions similaires

  1. [XL-2013] If Selection.Interior.ColorIndex = 40 Then Patient = "Ma"
    Par PICHOUX dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 21/02/2015, 09h57
  2. créer dans excel un bouton avec une macro personnalisée
    Par deubelte dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 20/11/2008, 16h01
  3. Réponses: 1
    Dernier message: 25/09/2007, 04h31
  4. Macro personnalisée - Problème d'espacement
    Par Aramis dans le forum Programmation (La)TeX avancée
    Réponses: 2
    Dernier message: 09/07/2007, 17h12
  5. Réponses: 4
    Dernier message: 23/12/2006, 16h55

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