bonjour à tous !
j'aimerais savoir comment je pourrais lire la formule présente dans une cellule précise afin de pouvoir l'exécuter.
merci d'avance pour votre aide![]()
bonjour à tous !
j'aimerais savoir comment je pourrais lire la formule présente dans une cellule précise afin de pouvoir l'exécuter.
merci d'avance pour votre aide![]()
quand tu dis que tu veux l'exécuter, tu veux en faite récupérer la formule d'une cellule et
- la recopier dans une autre pour l'exécuter
ou
- décoder la formule afin de l'inclure dans ton code ???
en fait je veux l'interpréter pour l'exécuter, donc la méthode à utiliser je sais pa trop en fait, laquelle me proposez vous ?
comprend pas ta question..Regarde peut etre les propriétés de "Formula"
- Avant de poster,
et http://www.developpez.com/sources/
- Lors du post, n'oubliez pas, si besoin les balises CODE => voir ici pour l'utilisation
- N'oubliez pas le
![]()
- N'oubliez pas le
si la réponse vous a été utile !
en fait je veux récupérer la formule présente dans une cellule en vba, puis l'exécuter automatiquement...
dites le si c'est toujours pa clair!
peut être devrais tu songer à récupérer chaque symbole et à lui affecter une opération. les chiffres ou lettres restant inchangés, les opérateurs emmenant à une procédure qui fait le même travail, etc... commencer par relever toutes les parenthèses et travailler en premier lieu sur l'intérieur de celle ci. et remplacer au fur et à mesure de "l'interprêtation" les nouvelles valeurs. (sait pas si c'est clair)
euh nan dsl pa trop, mais c'est pas grav je verrais sa après le déjeuner ! merci quand même et bon appétit a vous
!
peux tu nous dire ce que contient ta formule et ce que tu veux faire exactement avec si ça n'est pas confidentiel bien sur
car j'ai du mal à voir ce que tu veux obtenir
Envoyé par jimbololo
Comment ça l'éxécuter automatiquement ? normalement quand tu met une formule dans une cellule elle s'exécute![]()
- Avant de poster,
et http://www.developpez.com/sources/
- Lors du post, n'oubliez pas, si besoin les balises CODE => voir ici pour l'utilisation
- N'oubliez pas le
![]()
- N'oubliez pas le
si la réponse vous a été utile !
je donne un exemple :
la formule de la case est : x²*((y/a) + 30*(z-1)
il faut commencer par relever tout ceci dans une chaine strformule
1/tu décomposes ensuite ta chaine en cherchant la première parenthèse fermée ")" puis cherche la parenthèse ouvrante la plus proche sur la gauche de celle-ci dans la chaine.
2/tu mets tout ce qu'il y'a à l'intérieur dans une chaîne temporaire, que tu vas interpréter. pour ça, tu construis une méthode qui associe aux lettres (a, b, etc) les valeurs correspondantes (tu ne pourras pas calculer quoique ce soit si tu n'as pas les valeurs de ces lettres!)
tu associe chaque valeur chiffrée de la chaîne temporaire au vrai chiffre
et tu associes à chaque signe une sous procédure effectuant le rôle du signe.
par exemple, si tu tombes sur a*b : tu commences par remplacer a et b par leurs valeurs et tu envoies ces valeurs dans une procédures qui les multiplies.
3/ tu continue la recherche de parenthèse fermée en revenant à l'étape, et ainsi de suite jusqu'à ce que la formule entière soit décodées et transformée en une simple expression que tu pourras passé directement en 2/ (lorsqu'il n y aura plus de parenthèse). penses à mettre des ordres de priorité aux * et / par rapports aux + et -.
et c'est quoi tes x , a , b .... ? d'ou en connai tu la valeur ? et combien y en as t'il ...? a,b,c,d,e,f,g,..z,...???
j'ai imaginé une formule au sens littéral parce que je ne sais pas comment fonctionne excel. j'imagine que dans les cases se trouvent des chiffres, des valeurs. par exemple, que dans la formules, le "a" est en fait un identifiant d'une autre case, par exemple : la formule : case 1 = case 2 + case 3. dans ce cas, le "a" dans mon exemple équivaut à "case 1" et il faudra alors faire correspondre cette valeur dans le programme.
bien je souhaitais juste donner des idées, je n'ai pas les compétences pour réaliser ça, mais je souhaitais apporter mon aide![]()
bon apparement je n'ai pa besoin de la réexécutée, j'ai vu sa avec mon maître de stage, il me faut juste récupérer la formule telle quelle afin de la stockée dans une variable string que je réutiliserai plus tard...
ben as ce moment la c'est .Formula... ou .FormulaLocal![]()
oui désolé jvien de regardé un peu l'aide et j'ai vu la méthode .formulalocal, bon j'men vai essayé sa de suite. merci beaucoup a tous ceux qui m'ont aidé !![]()
Partager