Vba

Résolu
débutante vba Messages postés 9 Statut Membre -  
débutante vba Messages postés 9 Statut Membre -
bonjour a tous,

je cherche de l'aide concernant une formule a mettre en place sur un fichier excel. je souhaite mettre une couleur dans une cellule selon certaines conditiond qui sont au nombre de 4 et qui du coup m'empeche d'utiliser la mise en forme conditonelle d'excel. il faut par consequent que je fasse une programmation vbs et la cest le drame ! je ne sais absolument pas leifaire. il faudrait que pour les cellules suivantes f10 a f14 dselon le chiffre a linterieur une couleur soit automatiquement mise voila comment cela doit se decliner inferieur a 1,02 alors rouge entre 1,021 et 1,12 alord vert entre 1,121 et 1,2 alor jaune et au dela de1,21 alors bleu. pouvez vous m ' aider s'il vous plait !

7 réponses

Vaucluse Messages postés 27336 Date d'inscription   Statut Contributeur Dernière intervention   6 444
 
Bonsoir
en attendant B=VBA qui va surement venir, vous pouvez toujours:
Soit :
utiliser excel à partir de 2007 qui n'a pas de limitation de MFC ;-)
Soit :
(si vous admettez vide =équivalent à <1,02)
passer vos cellules F10 à F14 en rouge selon votre 1° condition
appliquez les autres, dans l'ordre, avec ces formules dans l'ordre:
Vert
=ET(F10>1,02;F10<=1,12)
en jaune
=F10<=1,2
en bleu
=F10>1,2

crdlmnt


0
débutante vba Messages postés 9 Statut Membre
 
ah bon je ne savais pas pour la mise en forme conditionnelle maos admettons que je le saisi sur excel 2007 si celui ci est consulte par la suite sur excel moins recent est ce que cela fonctionnera? et enfin comment le saisir car quand jai essaye toute la colonne est ressori rouge alors que ca ne remplissait pas les conditions de cette couleur... je suis desolee je suis vraiment debutante!
0
Vaucluse Messages postés 27336 Date d'inscription   Statut Contributeur Dernière intervention   6 444
 
Non les spécificités de 2007 ne fonctionneront pas sur les précédents;
par ailleurs, pour vous dire pourquoi tout est rouge, il faudrait nous dire quelle conditions vous appliquez,quelles fomules et dans quel ordre.
A vous lire
0
Vaucluse Messages postés 27336 Date d'inscription   Statut Contributeur Dernière intervention   6 444
 
Si vous avez un fichier test, placez le sur
https://www.cjoint.com/
et revenez ici placer le lien donné par me site
0
débutante vba Messages postés 9 Statut Membre
 
https://www.cjoint.com/?3DktPh05Eus

l'ideal serait que la formule s'applique à toutes les versions excel d'où le fait de passer en vba ...
0
Vaucluse Messages postés 27336 Date d'inscription   Statut Contributeur Dernière intervention   6 444
 
En vba je ne sais pas, mais mon ami Mike et qui vous suit , lui, sait et va surement résoudre le problème
Voila tout ce que je eux vous proposer avec trois conditions adaptées à 97-2003
https://www.cjoint.com/?CDktYiBfZ7G
Mais bien sur, les cellules à 0 sont à base rouge et vous n'avez pas de résultat qui motive le jaune.
J'ai aussi placé en F une formule qui permet d'éviter le #DIV/0 quand les lignes sont vides.
Je vous laisse avec Mike
crdlmnt
0
débutante vba Messages postés 9 Statut Membre
 
merci beaucoup pour votre aide!
0
Mike-31 Messages postés 19571 Date d'inscription   Statut Contributeur Dernière intervention   5 138
 
Salut,

Quelle version Excel as tu

A+
Mike-31

Une période d'échec est un moment rêvé pour semer les graines du savoir.
0
débutante vba Messages postés 9 Statut Membre
 
je travaille sur différente version mais la plupart du temps sur excel 2007
0
Mike-31 Messages postés 19571 Date d'inscription   Statut Contributeur Dernière intervention   5 138
 
Re,

bien sur on peut passer en VBA, mais lorsqu'on peu faire simple pourquoi s'en priver

Pour ma part j'aurai mis ma plage en rouge ce qui élimine une couleur et j'aurai traité les 3 couleurs suivantes, mettre la plage F10:F17 en surbrillance
Mise en forme conditionnelle

pour la couleur verte
=A10>1,02

Pour la couleur jaune
=A10>1,12

pour la couleur bleu
=F10>1,2

Maintenant si tu tiens au VBA, je mange vite fait et je t'écrit un code tout simple
0
débutante vba Messages postés 9 Statut Membre
 
il est vrai que la simplicite c'est le mieux lorsque nous avons le choix mais j'avoue que je prefere en vba car cela se genere tout seul et cela me permet un certain gain de temps dans mon activite mais je ne veux pas exagerer et je ne veux pas non plus que tu meurs de faim ou de sur charge de travail.a cause de moi !
0

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

Posez votre question
Mike-31 Messages postés 19571 Date d'inscription   Statut Contributeur Dernière intervention   5 138
 
Re,

Mourir de faim non ce n'est pas mon genre, surcharge de travail non plus j'ai un bon patron qui se nomme retraite.

bon passons aux choses sérieuses, pour ton fichier mis à notre disposition, commence par supprimer les mises en forme conditionnelle, puis clic droit sur l'onglet de ta feuille/Visualiser le code

colle ce code dans la partie blanche

Private Sub Worksheet_Calculate()
Dim Cellule As Range
Application.ScreenUpdating = False
For Each Cellule In Range("F10:F17")
If Cellule.Value <= 1.02 Then Cellule.Interior.ColorIndex = 3 'rouge
If Cellule.Value > 1.02 Then Cellule.Interior.ColorIndex = 4 'vert
If Cellule.Value > 1.12 Then Cellule.Interior.ColorIndex = 6 'jaune
If Cellule.Value > 1.21 Then Cellule.Interior.ColorIndex = 23 'bleu
Next
Application.ScreenUpdating = True
End Sub


Il est possible d'améliorer le code pour affecter des couleurs de ton choix en faisant référence à des cellules que tu coloriserais par exemple
A+
Mike-31

Une période d'échec est un moment rêvé pour semer les graines du savoir.
0
débutante vba Messages postés 9 Statut Membre
 
j'essaye des demain ta solution car pas d'acces au.pc ce soir ! en tout cas merci beaucoup de ton aide ! c'est vraiment gentil ! je te tiens au courant demain pour le resultat bonne soirer !
0
Vaucluse Messages postés 27336 Date d'inscription   Statut Contributeur Dernière intervention   6 444
 
Bonjour Mike
étant intéressé , j'ai tenté.. mais je n'ai pas réussi à la faire fonctionner? j'attend de voir si la demandeuse à réussi!
bien amicalement
0
Mike-31 Messages postés 19571 Date d'inscription   Statut Contributeur Dernière intervention   5 138
 
Salut l'ami,

Change les valeurs en C et I puisque les valeurs en F sont le résultat de cette division

https://www.cjoint.com/?CDlhYzMm3eT
0
Vaucluse Messages postés 27336 Date d'inscription   Statut Contributeur Dernière intervention   6 444
 
Exact Mike, merci.Avec le modèle, c'est mieux.
Bonne journée

Petite remarque: les cellules égales à 0 restent rouge net passe en bleu si on remplace 0 par "" N'y a t il pas moyen de mettre une condition si la cellule st égale à 0 pour ne pas les formater
0
débutante vba Messages postés 9 Statut Membre
 
Elle fonctionne parfaitement ! petite question si je veux mettre en place cette meme programmation sur plusieurs pages de ce meme classeur comment dois-je procéder ? encore merci beaucoup pour cette aide !
0
Mike-31 Messages postés 19571 Date d'inscription   Statut Contributeur Dernière intervention   5 138
 
Re,

Si les plages à surveiller sont exactement identique sur toutes les feuilles ce même code suffit, il suffit de le déplacer dans la Thisworkbook

Private Sub Workbook_SheetCalculate(ByVal Sh As Object)
Dim Cellule As Range
Application.ScreenUpdating = False
For Each Cellule In Range("F10:F17")
If Cellule.Offset(1, -3) = "" Then Cellule.Interior.ColorIndex = 15 'xlNone 'vide
If Cellule.Value <= 1.02 Then Cellule.Interior.ColorIndex = 3 'rouge
If Cellule.Value > 1.02 Then Cellule.Interior.ColorIndex = 4 'vert
If Cellule.Value > 1.12 Then Cellule.Interior.ColorIndex = 6 'jaune
If Cellule.Value > 1.21 Then Cellule.Interior.ColorIndex = 23 'bleu
If Cellule.Offset(0, -3) = "" Or Cellule.Offset(0, 3) = "" Then Cellule.Interior.ColorIndex = xlNone 'vide
Next
Application.ScreenUpdating = True
End Sub
0
débutante vba Messages postés 9 Statut Membre
 
Génial !!!! cela fonctionne parfaitement !!! merci beaucoup à tous les deux pour votre aide.
0
Mike-31 Messages postés 19571 Date d'inscription   Statut Contributeur Dernière intervention   5 138
 
Re,

Plusieurs possibilités, on pourrait tester la cellule en F en fin de procédure ou directement dans chaque ligne avec une conditionnelle if
dans l'exemple je préfère tester les cellule en C et I en rajoutant une ligne en fin de code

Private Sub Worksheet_Calculate()
Dim Cellule As Range
Application.ScreenUpdating = False
For Each Cellule In Range("F10:F17")
If Cellule.Offset(1, -3) = "" Then Cellule.Interior.ColorIndex = 15 'xlNone 'vide
If Cellule.Value <= 1.02 Then Cellule.Interior.ColorIndex = 3 'rouge
If Cellule.Value > 1.02 Then Cellule.Interior.ColorIndex = 4 'vert
If Cellule.Value > 1.12 Then Cellule.Interior.ColorIndex = 6 'jaune
If Cellule.Value > 1.21 Then Cellule.Interior.ColorIndex = 23 'bleu
If Cellule.Offset(0, -3) = "" Or Cellule.Offset(0, 3) = "" Then Cellule.Interior.ColorIndex = xlNone 'vide
Next
Application.ScreenUpdating = True
End Sub
0