Forme condition - Comment faire > 3 condition

Résolu/Fermé
anne-sof Messages postés 5 Date d'inscription mardi 15 juillet 2008 Statut Membre Dernière intervention 17 juillet 2008 - 15 juil. 2008 à 19:26
anne-sof Messages postés 5 Date d'inscription mardi 15 juillet 2008 Statut Membre Dernière intervention 17 juillet 2008 - 17 juil. 2008 à 18:15
Bonjour,


Je maitrise bien la fonction "Format conditionnel" mais comment faire lorsque l'on a + de 3 conditions?

Imaginons :
=A => Rouge
=B => Bleu
=C => Vert
=D => Orange

merci pour votre aide :-)

anne-sophie

8 réponses

eriiic Messages postés 24571 Date d'inscription mardi 11 septembre 2007 Statut Contributeur Dernière intervention 8 mai 2024 7 216
15 juil. 2008 à 21:06
Bonjour,

ou bien tout mettre en fond orange et ne tester que A B C
eric
1
g Messages postés 1262 Date d'inscription vendredi 23 avril 2004 Statut Membre Dernière intervention 15 mai 2017 572
15 juil. 2008 à 19:32
Bonjour,

Tu peux utiliiser le code VBA http://gerard.g.pagesperso-orange.fr/logexl_09.htm#mise_forme_cond

Bonne soirée.
0
anne-sof Messages postés 5 Date d'inscription mardi 15 juillet 2008 Statut Membre Dernière intervention 17 juillet 2008
16 juil. 2008 à 08:35
merci pour votre aide! J'ai pas mal avancé.
Cependant, j'ai besoin de tester un tres grand tableau (180 colonnes et 50 lignes).
J'enchaine donc 2 boucles, ce qui donne un temps de réponse tres (trop!) long.

Une idée?

merci,



Private Sub Worksheet_SelectionChange(ByVal Target As Range)


For j = 7 To 200

For i = 15 To 75 'rangées de 15 à 75

If Cells(i, j) = "C" Then
Cells(i, j).Interior.ColorIndex = 4
Else
If Cells(i, j) = "Cp" Then
Cells(i, j).Interior.ColorIndex = 45
Else
If Cells(i, j) = "M" Then
Cells(i, j).Interior.ColorIndex = 3
Else
If Cells(i, j) = "Su" Then
Cells(i, j).Interior.ColorIndex = 8
Else
If Cells(i, j) = "Sc" Then
Cells(i, j).Interior.ColorIndex = 33
Else
If Cells(i, j) = "F" Then
Cells(i, j).Interior.ColorIndex = 5
Else
If Cells(i, j) = "" Then
Cells(i, j).Interior.ColorIndex = 2

End If
End If
End If
End If
End If
End If
End If

Next i
Next j
End Sub
0
Raymond PENTIER Messages postés 58418 Date d'inscription lundi 13 août 2007 Statut Contributeur Dernière intervention 9 mai 2024 17 104
16 juil. 2008 à 06:37
Tu peux aussi passer à Excel 2007 ...
0
eriiic Messages postés 24571 Date d'inscription mardi 11 septembre 2007 Statut Contributeur Dernière intervention 8 mai 2024 7 216
16 juil. 2008 à 10:45
Bonjour,

Ce n'est pas 4 tests que tu as à faire mais plus, comme quoi il est important d'être précis dans une question...
Au passage tu as ElseIf qui existe et qui évite d'avoir 15 End If à la fin...

Ce qui est très long c'est de lire une cellule. Donc met cells(i,j) dans une variable au début et teste cette variable.
Ou mieux utilise la structure select case :
Select case cells(i,j)
case "A"
faire ceci
case "B"
faire celà
....etc
case else
'sinon faire ça
end select

Si ce n'est tjs pas assez rapide il faut lire d'un bloc toute la plage dans une variable tableau et tester sur ce tableau.

Maintenant tes C, Cp, M,... sont-ils le résultat d'une formule ou d'une saisie ?
Si c'est le résultat d'une saisie tu as la cellule concernée dans Target. Dans ce cas plus besoin de boucle sur toutes les cellules et remplacer Cells(i, j). par Target.

eric
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
anne-sof Messages postés 5 Date d'inscription mardi 15 juillet 2008 Statut Membre Dernière intervention 17 juillet 2008
16 juil. 2008 à 12:17
Bonjour eric,

Merci pour ton aide,
Ca marche nettement mieux et c'est plus lisible :

Par contre, voici cela necessite :
1. tu saisis ton code (ex : C)
2. tu fais entrer ou suivant
3. il faut revenir sur la cellule pour que celle-ci se colorie

Y-at-il un truc pour que cela se colorie en meme temps lorsque l'on change de cellule?

voici le script :

Private Sub Worksheet_SelectionChange(ByVal Target As Range)

Dim Plage As Range

Set Plage = Range("G15:HZ75")

Select Case (Target.Value)
Case "C": Target.Interior.ColorIndex = 4
Case "Cp": Target.Interior.ColorIndex = 45
Case "M": Target.Interior.ColorIndex = 3
Case "Su": Target.Interior.ColorIndex = 8
Case "Sc": Target.Interior.ColorIndex = 33
Case "F": Target.Interior.ColorIndex = 5
Case "": Target.Interior.ColorIndex = 2
End Select

End Sub
0
eriiic Messages postés 24571 Date d'inscription mardi 11 septembre 2007 Statut Contributeur Dernière intervention 8 mai 2024 7 216
16 juil. 2008 à 12:20
et si tu répondais à la question Maintenant tes C, Cp, M,... sont-ils le résultat d'une formule ou d'une saisie ?
0
anne-sof Messages postés 5 Date d'inscription mardi 15 juillet 2008 Statut Membre Dernière intervention 17 juillet 2008
16 juil. 2008 à 17:32
Ce sont le résultat d'une saisie dans le tableau
0
eriiic Messages postés 24571 Date d'inscription mardi 11 septembre 2007 Statut Contributeur Dernière intervention 8 mai 2024 7 216
16 juil. 2008 à 19:15
Utilise l'evenement Change plutôt que SelectionChange,
et si tu veux que la macro n'agisse que sur la plage G15:HZ75 ajoute If intersect....then...

Private Sub Worksheet_Change(ByVal Target As Range)
    If Intersect(Target, Range("G15:HZ75")) Is Nothing Then Exit Sub
    Select Case (Target.Value)
    Case "C": Target.Interior.ColorIndex = 4
    Case "Cp": Target.Interior.ColorIndex = 45
    Case "M": Target.Interior.ColorIndex = 3
    Case "Su": Target.Interior.ColorIndex = 8
    Case "Sc": Target.Interior.ColorIndex = 33
    Case "F": Target.Interior.ColorIndex = 5
    Case "": Target.Interior.ColorIndex = 2
    End Select
End Sub


eric
0
g Messages postés 1262 Date d'inscription vendredi 23 avril 2004 Statut Membre Dernière intervention 15 mai 2017 572
17 juil. 2008 à 09:02
Bonjour,

La solution d' eriiic est à conjuguer au "plus que parfait"....

Concernant la couleur "blanc" des cellules vidées, il est préférable d'utliser

Case "": Target.Interior.ColorIndex = xlNone

afin de conserver le quadrillage.

Bonne journée.
0
eriiic Messages postés 24571 Date d'inscription mardi 11 septembre 2007 Statut Contributeur Dernière intervention 8 mai 2024 7 216
17 juil. 2008 à 09:19
Bonjour,

Tout à fait exact, merci pour le complément
eric
0
anne-sof Messages postés 5 Date d'inscription mardi 15 juillet 2008 Statut Membre Dernière intervention 17 juillet 2008 > eriiic Messages postés 24571 Date d'inscription mardi 11 septembre 2007 Statut Contributeur Dernière intervention 8 mai 2024
17 juil. 2008 à 18:15
Et bien merci pour toute cette aide... comme quoi un PC + internet + des gens sympas et pas besoin de connaitre le VBA on copie/colle...

Merci à tous

Je passe la question au vert!

Bonne soirée à tous
0