[VB-EXCEL] Insertion variable dans formule

Doudou95 Messages postés 1561 Date d'inscription   Statut Membre Dernière intervention   -  
jjsteing Messages postés 1670 Date d'inscription   Statut Contributeur Dernière intervention   -
Bonjour,
Je souhaiterai savoir s'il est possible de placer une variable dans une formule.
Je m'explique :
Je souhaite inscrire successivement une formule dans une suite de cellules via un code VB car la formule change en fonction de la case choisie dans une list box.
Pour simplifier le code je souhaite savoir si, dans la formule inscrite dans le code, on peut insérer une variable dont la valeur changera suivant la case sélectionnée dans la list box.


PS: Comment inscrire une formule matricielle et non simple formule(.FORMULA) via un code?

Merci Cordialement
A voir également:

28 réponses

Doudou95 Messages postés 1561 Date d'inscription   Statut Membre Dernière intervention   275
 
Bonjour,
Bon quand je test il me trouve non stop des problèmes dans la fonction O_O
0
jjsteing Messages postés 1670 Date d'inscription   Statut Contributeur Dernière intervention   181
 
quel genre de proble ?
0
Doudou95 Messages postés 1561 Date d'inscription   Statut Membre Dernière intervention   275
 
Bonjour,
Alors j'ai testé tout ça :

- Quand je test sur une colonne dont les cellules contiennent des valeurs qui ne sont pas des dates et qui ne sont pas soumises à une mise en forme conditionnelle, j'obtiens nbvertes = | nboranges= | total = 0

- Quand je test sur une colonne dont les cellules contiennent des dates et qui sont soumises à une mise en forme conditionnelle, j'obtiens à la ligne "If Application.Evaluate(FC.Formula1) Then" l'erreur "incompatibilité de types"...

Comment ça se fait? help me encore plz en attendant je vais reprendre ton fichier et voir un peu encore :s

help merci
0
jjsteing Messages postés 1670 Date d'inscription   Statut Contributeur Dernière intervention   181
 
Ah ben voila.. dis moi exactement comment se fait ta forme conditionnelle...
Dans le module, je ne gere que <,>,<=,>=,=.. alors si c'est autre chose, il le gere pas ;) mais y a moyen de le gérer :p
0
Doudou95 Messages postés 1561 Date d'inscription   Statut Membre Dernière intervention   275
 
Voila :

condition case verte
=SI(AUJOURDHUI()-S178<($S$5*365*0,8);VRAI;FAUX)

condition case rouge
=ET(S178<>"";SI(AUJOURDHUI()-S178>($S$5*365);VRAI;FAUX))

condition case orange
=ET(S178<>"";SI(AUJOURDHUI()-S178>=($S$5*365*0,8);VRAI;FAUX))

Attention ces conditions sont liée à la cellule S178
0
Doudou95 Messages postés 1561 Date d'inscription   Statut Membre Dernière intervention   275 > Doudou95 Messages postés 1561 Date d'inscription   Statut Membre Dernière intervention  
 
lol tu t'en sors? moi j'galère sur une fenêtre à enlever le mastic actuellement :(
0
jjsteing Messages postés 1670 Date d'inscription   Statut Contributeur Dernière intervention   181
 
Alors.. apres une grosse recherche et une mega prise de tete.. je pense que j'ai trouver.. mais ca va pas etre facile à gérer..

Le truc c'est que evaluate evalue la fonction au format anglais.. donc tes si, aujourdhui, faux et vrai.. ben .. ca loui plait pas...

J'essai de trouver une parade ;)
0

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

Posez votre question
jjsteing Messages postés 1670 Date d'inscription   Statut Contributeur Dernière intervention   181
 
une piste ici...
http://www.glossaire.be/english_french/glossaire_excel_fonction_anglais_francais.htm

mais c'est pas du gateau:s
0
jjsteing Messages postés 1670 Date d'inscription   Statut Contributeur Dernière intervention   181
 
Sinon, met ta formule dans une autre case qui renverrais 1 2 ou 3 (sans passer par la forme conditionnelle. et en fonction faire la forme conditionnelle en passant par l'assistant (<,<=,>,>=;==) qui lui est gérer par le module ;)

Enfin, si tu m a compris :p


mais je continu de chercher ;)
0
Doudou95 Messages postés 1561 Date d'inscription   Statut Membre Dernière intervention   275
 
re
Bon alors on a 2 choix
- ou tu te casses toute la nuit pour moi car j'avoue que je suis dépassé la et jdois finir pour demain aprem.
- ou si j'ai bien compris je mets ça via des formules dans une page cachée spéciale pour la synthèse avec 1,2,3...
Mais dans ce cas il me faudrait la formule à mettre dans la page cachée et me donner donc l'appel modifié de la fonction VB
Je suis désolé de te demander de marcher mon travail mais la j'arrive au bout du délai et j'aimerai que tout soit près.
Malheureusement je n'ai pas le fichier car je ne peux pas le sortir du taff en tous cas merci!
0
jjsteing Messages postés 1670 Date d'inscription   Statut Contributeur Dernière intervention   181 > Doudou95 Messages postés 1561 Date d'inscription   Statut Membre Dernière intervention  
 
ah ben je pense que c'est trop tard alors :s

Bon, ben petite explication quabd meme.. au cas ou...

Actuellement tu à une mise en forme conditionnelle qui à 3 formules :

condition case verte
=SI(AUJOURDHUI()-S178<($S$5*365*0,8);VRAI;FAUX)

condition case rouge
=ET(S178<>"";SI(AUJOURDHUI()-S178>($S$5*365);VRAI;FAUX))

condition case orange
=ET(S178<>"";SI(AUJOURDHUI()-S178>($S$5*365);VRAI;FAUX))

ma solution serrait de mettre dans une autre colonne :

=SI(AUJOURDHUI()-S178<($S$5*365*0,8);1;SI(AUJOURDHUI()-S178>($S$5*365);2;SI(AUJOURDHUI()-S178>($S$5*365);3;4)))

En esperant que tu n ai jamais 4...

donc ca t'affiche 1 2 3.. et donc tu peux faire la mise en forme conditionnelle sur cette colonne avec plutot que 'la formule est' choisir 'la valeur de la cellule est' et là, le module fonctionnera ;)
0
Doudou95 Messages postés 1561 Date d'inscription   Statut Membre Dernière intervention   275
 
Coucou
d'abord merci pour ton aide alors je suis passé par une feuille de calcul et via la formule Si(G9<>"";Si(G9+($G$5*365)<AUJOURD'HUI;0;1);"TEXTE")
(peut être une faute les 2 pc sont pas cote à cote)

Bref je passe par cette formule ca me donne donc bien par le NB.SI de valeur 1 le même nombre de personnes que dans la synthèse globale du fichier.

Maintenant je sais pas comment y inclure une triple condition
ca reprend l'idée d'avant en prog c'est à dire :
Si L1 = "1" (date verte ou orange) ET Si A1 = "Direction" (service) ET Si B1 = "Chef" (poste)

une idée ? je veux pas faire d'erreurs de syntaxe ou autre car après cette formule s'adapte à chaque "service" et "poste" si je puis dire.

merci de ton aide
0
jjsteing Messages postés 1670 Date d'inscription   Statut Contributeur Dernière intervention   181
 
re ;)

envoie moi un exemple car là... je sait pas si tu est en forme conditionnelle ou pas ... pour info, j ai garder les exemples que j avais tester pour toi ;)
0