J'utilise un fichier excel composé de 2 feuilles.
La premiere est un calculateur et la deuxieme sert à afficher les
reponses en fonction de cellule en colonne :
A B
1 50 ( issu du calculateur qui prend 1 en parametre )
2 100 ( issu du calculateur qui prend 2 en parametre )
etc....
J'arrive a récupérer les valeurs de la 2ème feuille, les mettre une a
une dans le calculateur, mais celui ci ne s'active pas.
J'obtiens toujours le resultat par défaut dans la colonne B
Quelqu'un connait il comme relancer le calcul dans ma 1ere feuille une
fois la valeur de A positionnée ?
Je comte surement migrer vers OO, peut etre est ce plus simple, avez
vous des conseils ou des utiles la dessus ( j'avoue ne pas encore avoir
chercher.... )
Cette action est irreversible, confirmez la suppression du commentaire ?
Signaler le commentaire
Veuillez sélectionner un problème
Nudité
Violence
Harcèlement
Fraude
Vente illégale
Discours haineux
Terrorisme
Autre
Amaury Forgeot d'Arc
Bonjour,
J'utilise un fichier excel composé de 2 feuilles. La premiere est un calculateur et la deuxieme sert à afficher les reponses en fonction de cellule en colonne :
A B 1 50 ( issu du calculateur qui prend 1 en parametre ) 2 100 ( issu du calculateur qui prend 2 en parametre ) etc....
J'arrive a récupérer les valeurs de la 2ème feuille, les mettre une a une dans le calculateur, mais celui ci ne s'active pas. J'obtiens toujours le resultat par défaut dans la colonne B
Quelqu'un connait il comme relancer le calcul dans ma 1ere feuille une fois la valeur de A positionnée ?
As-tu essayé la commande Calculate ? C'est un peu comme quand on appuie sur la touche F9 dans Excel.
Remarque: j'ai piqué l'idée sur un site qui parle de Visual Basic. Ce sont vraiment les mêmes commandes, et la plupart des gens font encore leurs macros Excel en basic...
-- Amaury
Bonjour,
J'utilise un fichier excel composé de 2 feuilles.
La premiere est un calculateur et la deuxieme sert à afficher les
reponses en fonction de cellule en colonne :
A B
1 50 ( issu du calculateur qui prend 1 en parametre )
2 100 ( issu du calculateur qui prend 2 en parametre )
etc....
J'arrive a récupérer les valeurs de la 2ème feuille, les mettre une a
une dans le calculateur, mais celui ci ne s'active pas.
J'obtiens toujours le resultat par défaut dans la colonne B
Quelqu'un connait il comme relancer le calcul dans ma 1ere feuille une
fois la valeur de A positionnée ?
As-tu essayé la commande Calculate ?
C'est un peu comme quand on appuie sur la touche F9 dans Excel.
Remarque: j'ai piqué l'idée sur un site qui parle de Visual Basic.
Ce sont vraiment les mêmes commandes, et la plupart des gens font encore
leurs macros Excel en basic...
J'utilise un fichier excel composé de 2 feuilles. La premiere est un calculateur et la deuxieme sert à afficher les reponses en fonction de cellule en colonne :
A B 1 50 ( issu du calculateur qui prend 1 en parametre ) 2 100 ( issu du calculateur qui prend 2 en parametre ) etc....
J'arrive a récupérer les valeurs de la 2ème feuille, les mettre une a une dans le calculateur, mais celui ci ne s'active pas. J'obtiens toujours le resultat par défaut dans la colonne B
Quelqu'un connait il comme relancer le calcul dans ma 1ere feuille une fois la valeur de A positionnée ?
As-tu essayé la commande Calculate ? C'est un peu comme quand on appuie sur la touche F9 dans Excel.
Remarque: j'ai piqué l'idée sur un site qui parle de Visual Basic. Ce sont vraiment les mêmes commandes, et la plupart des gens font encore leurs macros Excel en basic...
-- Amaury
MCI, Shadok Gouroudoudou
Bonjour !
Comme l'a dit Amaury, "Calculate()" est une fonction publique OLE-automation d'Excel. Elle est également utilisée par le VBA (Basic) interne d'Excel. Le makepy a d'ailleurs déjà dû te donner cette info.
Par contre, tu ne précises pas quel mode de calcul tu utilises dans tes feuilles. S'il s'agit du mode "automatique", le problème est autre.
Il est également possible de modifier ce paramètre avec Python : exobj.application.calculation = -4135 (mode "calcul sur ordre") exobj.application.calculation = -4105 (mode "calcul automatique")
Concernant OOo, le gros avantage de ce logiciel, c'est qu'il est gratuit. Mais, son pilotage via COM (Ole-automation), par Python, est plus compliqué qu'Excel, moins puissant, et limité par un bug d'OOo, qui plante le passage de paramètres tableaux/collection de/vers Python.
Néanmoins, on arrive à faire des choses.
Une alternative serait d'utiliser le Python (Python 2.3)) interne à OOo. Mais, c'est plutôt lourd et contraignant (impossible d'installer des modules comme PyWin dedans ; difficulté à l'utiliser "de l'extérieur").
Tant qu'on y ait sur les trucs libres, je regrette que Gnumeric n'ait ni macros, ni ouverture programmable, car c'est, par ailleurs un excellent tableur (même s'il est plus lent et plus gourmand que ce qu'en disent ses fans).
-- @-salutations
Michel Claveau
Bonjour !
Comme l'a dit Amaury, "Calculate()" est une fonction publique
OLE-automation d'Excel. Elle est également utilisée par le VBA (Basic)
interne d'Excel.
Le makepy a d'ailleurs déjà dû te donner cette info.
Par contre, tu ne précises pas quel mode de calcul tu utilises dans tes
feuilles. S'il s'agit du mode "automatique", le problème est autre.
Il est également possible de modifier ce paramètre avec Python :
exobj.application.calculation = -4135 (mode "calcul sur ordre")
exobj.application.calculation = -4105 (mode "calcul automatique")
Concernant OOo, le gros avantage de ce logiciel, c'est qu'il est
gratuit.
Mais, son pilotage via COM (Ole-automation), par Python, est plus
compliqué qu'Excel, moins puissant, et limité par un bug d'OOo, qui
plante le passage de paramètres tableaux/collection de/vers Python.
Néanmoins, on arrive à faire des choses.
Une alternative serait d'utiliser le Python (Python 2.3)) interne à
OOo. Mais, c'est plutôt lourd et contraignant (impossible d'installer
des modules comme PyWin dedans ; difficulté à l'utiliser "de
l'extérieur").
Tant qu'on y ait sur les trucs libres, je regrette que Gnumeric n'ait
ni macros, ni ouverture programmable, car c'est, par ailleurs un
excellent tableur (même s'il est plus lent et plus gourmand que ce
qu'en disent ses fans).
Comme l'a dit Amaury, "Calculate()" est une fonction publique OLE-automation d'Excel. Elle est également utilisée par le VBA (Basic) interne d'Excel. Le makepy a d'ailleurs déjà dû te donner cette info.
Par contre, tu ne précises pas quel mode de calcul tu utilises dans tes feuilles. S'il s'agit du mode "automatique", le problème est autre.
Il est également possible de modifier ce paramètre avec Python : exobj.application.calculation = -4135 (mode "calcul sur ordre") exobj.application.calculation = -4105 (mode "calcul automatique")
Concernant OOo, le gros avantage de ce logiciel, c'est qu'il est gratuit. Mais, son pilotage via COM (Ole-automation), par Python, est plus compliqué qu'Excel, moins puissant, et limité par un bug d'OOo, qui plante le passage de paramètres tableaux/collection de/vers Python.
Néanmoins, on arrive à faire des choses.
Une alternative serait d'utiliser le Python (Python 2.3)) interne à OOo. Mais, c'est plutôt lourd et contraignant (impossible d'installer des modules comme PyWin dedans ; difficulté à l'utiliser "de l'extérieur").
Tant qu'on y ait sur les trucs libres, je regrette que Gnumeric n'ait ni macros, ni ouverture programmable, car c'est, par ailleurs un excellent tableur (même s'il est plus lent et plus gourmand que ce qu'en disent ses fans).
-- @-salutations
Michel Claveau
jean-michel bain-cornu
Bonjour,
Tant qu'on y ait sur les trucs libres, je regrette que Gnumeric n'ait ni macros, ni ouverture programmable, car c'est, par ailleurs un excellent tableur (même s'il est plus lent et plus gourmand que ce qu'en disent ses fans).
Il y a pourtant ceci (Python Programming in Gnumeric) : http://www.csse.monash.edu.au/~ctwardy/starting-with-python.html As-tu déjà jeté un oeil ? Mais sans doute cela n'est-il pas possible sous windows.
Bonjour,
Tant qu'on y ait sur les trucs libres, je regrette que Gnumeric n'ait ni
macros, ni ouverture programmable, car c'est, par ailleurs un excellent
tableur (même s'il est plus lent et plus gourmand que ce qu'en disent
ses fans).
Il y a pourtant ceci (Python Programming in Gnumeric) :
http://www.csse.monash.edu.au/~ctwardy/starting-with-python.html
As-tu déjà jeté un oeil ? Mais sans doute cela n'est-il pas possible
sous windows.
Tant qu'on y ait sur les trucs libres, je regrette que Gnumeric n'ait ni macros, ni ouverture programmable, car c'est, par ailleurs un excellent tableur (même s'il est plus lent et plus gourmand que ce qu'en disent ses fans).
Il y a pourtant ceci (Python Programming in Gnumeric) : http://www.csse.monash.edu.au/~ctwardy/starting-with-python.html As-tu déjà jeté un oeil ? Mais sans doute cela n'est-il pas possible sous windows.
ReM
Bonjour,
J'utilise un fichier excel composé de 2 feuilles. La premiere est un calculateur et la deuxieme sert à afficher les reponses en fonction de cellule en colonne :
A B 1 50 ( issu du calculateur qui prend 1 en parametre ) 2 100 ( issu du calculateur qui prend 2 en parametre ) etc....
J'arrive a récupérer les valeurs de la 2ème feuille, les mettre une a une dans le calculateur, mais celui ci ne s'active pas. J'obtiens toujours le resultat par défaut dans la colonne B
Quelqu'un connait il comme relancer le calcul dans ma 1ere feuille une fois la valeur de A positionnée ?
As-tu essayé la commande Calculate ? C'est un peu comme quand on appuie sur la touche F9 dans Excel.
Remarque: j'ai piqué l'idée sur un site qui parle de Visual Basic. Ce sont vraiment les mêmes commandes, et la plupart des gens font encore leurs macros Excel en basic...
Bonjour,
J'utilise un fichier excel composé de 2 feuilles.
La premiere est un calculateur et la deuxieme sert à afficher les
reponses en fonction de cellule en colonne :
A B
1 50 ( issu du calculateur qui prend 1 en parametre )
2 100 ( issu du calculateur qui prend 2 en parametre )
etc....
J'arrive a récupérer les valeurs de la 2ème feuille, les mettre une a
une dans le calculateur, mais celui ci ne s'active pas.
J'obtiens toujours le resultat par défaut dans la colonne B
Quelqu'un connait il comme relancer le calcul dans ma 1ere feuille une
fois la valeur de A positionnée ?
As-tu essayé la commande Calculate ?
C'est un peu comme quand on appuie sur la touche F9 dans Excel.
Remarque: j'ai piqué l'idée sur un site qui parle de Visual Basic.
Ce sont vraiment les mêmes commandes, et la plupart des gens font encore
leurs macros Excel en basic...
J'utilise un fichier excel composé de 2 feuilles. La premiere est un calculateur et la deuxieme sert à afficher les reponses en fonction de cellule en colonne :
A B 1 50 ( issu du calculateur qui prend 1 en parametre ) 2 100 ( issu du calculateur qui prend 2 en parametre ) etc....
J'arrive a récupérer les valeurs de la 2ème feuille, les mettre une a une dans le calculateur, mais celui ci ne s'active pas. J'obtiens toujours le resultat par défaut dans la colonne B
Quelqu'un connait il comme relancer le calcul dans ma 1ere feuille une fois la valeur de A positionnée ?
As-tu essayé la commande Calculate ? C'est un peu comme quand on appuie sur la touche F9 dans Excel.
Remarque: j'ai piqué l'idée sur un site qui parle de Visual Basic. Ce sont vraiment les mêmes commandes, et la plupart des gens font encore leurs macros Excel en basic...
ReM
Bonsoir
Je reviens tardivement sur mon problème que j'avais mis de coté un temps. Après plusieurs essais avec la solution du Range().Calculate() ou du application.calculation = -4105, je n'ai toujours pas de raffraichissement de ma première feuille pour écrire le résultat dans la deuxième. Je joins mon code si qqun a une idée, je gagnerais beaucoup de temps dans le remplissage des feuilles.
Comme l'a dit Amaury, "Calculate()" est une fonction publique OLE-automation d'Excel. Elle est également utilisée par le VBA (Basic) interne d'Excel. Le makepy a d'ailleurs déjà dû te donner cette info.
Par contre, tu ne précises pas quel mode de calcul tu utilises dans tes feuilles. S'il s'agit du mode "automatique", le problème est autre.
Il est également possible de modifier ce paramètre avec Python : exobj.application.calculation = -4135 (mode "calcul sur ordre") exobj.application.calculation = -4105 (mode "calcul automatique")
Concernant OOo, le gros avantage de ce logiciel, c'est qu'il est gratuit. Mais, son pilotage via COM (Ole-automation), par Python, est plus compliqué qu'Excel, moins puissant, et limité par un bug d'OOo, qui plante le passage de paramètres tableaux/collection de/vers Python.
Néanmoins, on arrive à faire des choses.
Une alternative serait d'utiliser le Python (Python 2.3)) interne à OOo. Mais, c'est plutôt lourd et contraignant (impossible d'installer des modules comme PyWin dedans ; difficulté à l'utiliser "de l'extérieur").
Tant qu'on y ait sur les trucs libres, je regrette que Gnumeric n'ait ni macros, ni ouverture programmable, car c'est, par ailleurs un excellent tableur (même s'il est plus lent et plus gourmand que ce qu'en disent ses fans).
Bonsoir
Je reviens tardivement sur mon problème que j'avais mis de coté un temps.
Après plusieurs essais avec la solution du Range().Calculate()
ou du application.calculation = -4105, je n'ai toujours pas de
raffraichissement de ma première feuille pour écrire le résultat dans la
deuxième.
Je joins mon code si qqun a une idée, je gagnerais beaucoup de temps
dans le remplissage des feuilles.
Comme l'a dit Amaury, "Calculate()" est une fonction publique
OLE-automation d'Excel. Elle est également utilisée par le VBA (Basic)
interne d'Excel.
Le makepy a d'ailleurs déjà dû te donner cette info.
Par contre, tu ne précises pas quel mode de calcul tu utilises dans tes
feuilles. S'il s'agit du mode "automatique", le problème est autre.
Il est également possible de modifier ce paramètre avec Python :
exobj.application.calculation = -4135 (mode "calcul sur ordre")
exobj.application.calculation = -4105 (mode "calcul automatique")
Concernant OOo, le gros avantage de ce logiciel, c'est qu'il est gratuit.
Mais, son pilotage via COM (Ole-automation), par Python, est plus
compliqué qu'Excel, moins puissant, et limité par un bug d'OOo, qui
plante le passage de paramètres tableaux/collection de/vers Python.
Néanmoins, on arrive à faire des choses.
Une alternative serait d'utiliser le Python (Python 2.3)) interne à OOo.
Mais, c'est plutôt lourd et contraignant (impossible d'installer des
modules comme PyWin dedans ; difficulté à l'utiliser "de l'extérieur").
Tant qu'on y ait sur les trucs libres, je regrette que Gnumeric n'ait ni
macros, ni ouverture programmable, car c'est, par ailleurs un excellent
tableur (même s'il est plus lent et plus gourmand que ce qu'en disent
ses fans).
Je reviens tardivement sur mon problème que j'avais mis de coté un temps. Après plusieurs essais avec la solution du Range().Calculate() ou du application.calculation = -4105, je n'ai toujours pas de raffraichissement de ma première feuille pour écrire le résultat dans la deuxième. Je joins mon code si qqun a une idée, je gagnerais beaucoup de temps dans le remplissage des feuilles.
Comme l'a dit Amaury, "Calculate()" est une fonction publique OLE-automation d'Excel. Elle est également utilisée par le VBA (Basic) interne d'Excel. Le makepy a d'ailleurs déjà dû te donner cette info.
Par contre, tu ne précises pas quel mode de calcul tu utilises dans tes feuilles. S'il s'agit du mode "automatique", le problème est autre.
Il est également possible de modifier ce paramètre avec Python : exobj.application.calculation = -4135 (mode "calcul sur ordre") exobj.application.calculation = -4105 (mode "calcul automatique")
Concernant OOo, le gros avantage de ce logiciel, c'est qu'il est gratuit. Mais, son pilotage via COM (Ole-automation), par Python, est plus compliqué qu'Excel, moins puissant, et limité par un bug d'OOo, qui plante le passage de paramètres tableaux/collection de/vers Python.
Néanmoins, on arrive à faire des choses.
Une alternative serait d'utiliser le Python (Python 2.3)) interne à OOo. Mais, c'est plutôt lourd et contraignant (impossible d'installer des modules comme PyWin dedans ; difficulté à l'utiliser "de l'extérieur").
Tant qu'on y ait sur les trucs libres, je regrette que Gnumeric n'ait ni macros, ni ouverture programmable, car c'est, par ailleurs un excellent tableur (même s'il est plus lent et plus gourmand que ce qu'en disent ses fans).
ReM
Personne ne semble avoir de solution. OpenOffice sera-t-il plus performant ? Un dernière p'tit conseil, svp !!!
ReM
Bonsoir
Je reviens tardivement sur mon problème que j'avais mis de coté un temps. Après plusieurs essais avec la solution du Range().Calculate() ou du application.calculation = -4105, je n'ai toujours pas de raffraichissement de ma première feuille pour écrire le résultat dans la deuxième. Je joins mon code si qqun a une idée, je gagnerais beaucoup de temps dans le remplissage des feuilles.
Comme l'a dit Amaury, "Calculate()" est une fonction publique OLE-automation d'Excel. Elle est également utilisée par le VBA (Basic) interne d'Excel. Le makepy a d'ailleurs déjà dû te donner cette info.
Par contre, tu ne précises pas quel mode de calcul tu utilises dans tes feuilles. S'il s'agit du mode "automatique", le problème est autre.
Il est également possible de modifier ce paramètre avec Python : exobj.application.calculation = -4135 (mode "calcul sur ordre") exobj.application.calculation = -4105 (mode "calcul automatique")
Concernant OOo, le gros avantage de ce logiciel, c'est qu'il est gratuit. Mais, son pilotage via COM (Ole-automation), par Python, est plus compliqué qu'Excel, moins puissant, et limité par un bug d'OOo, qui plante le passage de paramètres tableaux/collection de/vers Python.
Néanmoins, on arrive à faire des choses.
Une alternative serait d'utiliser le Python (Python 2.3)) interne à OOo. Mais, c'est plutôt lourd et contraignant (impossible d'installer des modules comme PyWin dedans ; difficulté à l'utiliser "de l'extérieur").
Tant qu'on y ait sur les trucs libres, je regrette que Gnumeric n'ait ni macros, ni ouverture programmable, car c'est, par ailleurs un excellent tableur (même s'il est plus lent et plus gourmand que ce qu'en disent ses fans).
Personne ne semble avoir de solution.
OpenOffice sera-t-il plus performant ?
Un dernière p'tit conseil, svp !!!
ReM
Bonsoir
Je reviens tardivement sur mon problème que j'avais mis de coté un temps.
Après plusieurs essais avec la solution du Range().Calculate()
ou du application.calculation = -4105, je n'ai toujours pas de
raffraichissement de ma première feuille pour écrire le résultat dans la
deuxième.
Je joins mon code si qqun a une idée, je gagnerais beaucoup de temps
dans le remplissage des feuilles.
Comme l'a dit Amaury, "Calculate()" est une fonction publique
OLE-automation d'Excel. Elle est également utilisée par le VBA (Basic)
interne d'Excel.
Le makepy a d'ailleurs déjà dû te donner cette info.
Par contre, tu ne précises pas quel mode de calcul tu utilises dans
tes feuilles. S'il s'agit du mode "automatique", le problème est autre.
Il est également possible de modifier ce paramètre avec Python :
exobj.application.calculation = -4135 (mode "calcul sur ordre")
exobj.application.calculation = -4105 (mode "calcul automatique")
Concernant OOo, le gros avantage de ce logiciel, c'est qu'il est gratuit.
Mais, son pilotage via COM (Ole-automation), par Python, est plus
compliqué qu'Excel, moins puissant, et limité par un bug d'OOo, qui
plante le passage de paramètres tableaux/collection de/vers Python.
Néanmoins, on arrive à faire des choses.
Une alternative serait d'utiliser le Python (Python 2.3)) interne à
OOo. Mais, c'est plutôt lourd et contraignant (impossible d'installer
des modules comme PyWin dedans ; difficulté à l'utiliser "de
l'extérieur").
Tant qu'on y ait sur les trucs libres, je regrette que Gnumeric n'ait
ni macros, ni ouverture programmable, car c'est, par ailleurs un
excellent tableur (même s'il est plus lent et plus gourmand que ce
qu'en disent ses fans).
Personne ne semble avoir de solution. OpenOffice sera-t-il plus performant ? Un dernière p'tit conseil, svp !!!
ReM
Bonsoir
Je reviens tardivement sur mon problème que j'avais mis de coté un temps. Après plusieurs essais avec la solution du Range().Calculate() ou du application.calculation = -4105, je n'ai toujours pas de raffraichissement de ma première feuille pour écrire le résultat dans la deuxième. Je joins mon code si qqun a une idée, je gagnerais beaucoup de temps dans le remplissage des feuilles.
Comme l'a dit Amaury, "Calculate()" est une fonction publique OLE-automation d'Excel. Elle est également utilisée par le VBA (Basic) interne d'Excel. Le makepy a d'ailleurs déjà dû te donner cette info.
Par contre, tu ne précises pas quel mode de calcul tu utilises dans tes feuilles. S'il s'agit du mode "automatique", le problème est autre.
Il est également possible de modifier ce paramètre avec Python : exobj.application.calculation = -4135 (mode "calcul sur ordre") exobj.application.calculation = -4105 (mode "calcul automatique")
Concernant OOo, le gros avantage de ce logiciel, c'est qu'il est gratuit. Mais, son pilotage via COM (Ole-automation), par Python, est plus compliqué qu'Excel, moins puissant, et limité par un bug d'OOo, qui plante le passage de paramètres tableaux/collection de/vers Python.
Néanmoins, on arrive à faire des choses.
Une alternative serait d'utiliser le Python (Python 2.3)) interne à OOo. Mais, c'est plutôt lourd et contraignant (impossible d'installer des modules comme PyWin dedans ; difficulté à l'utiliser "de l'extérieur").
Tant qu'on y ait sur les trucs libres, je regrette que Gnumeric n'ait ni macros, ni ouverture programmable, car c'est, par ailleurs un excellent tableur (même s'il est plus lent et plus gourmand que ce qu'en disent ses fans).
Laurent Pointal
ReM wrote:
Personne ne semble avoir de solution. OpenOffice sera-t-il plus performant ? Un dernière p'tit conseil, svp !!!
Ben, si ça ne répond pas dans la commnauté francophone, aller poser la question à la (plus large) communauté anglophone sur comp.lang.python (en traduisant la question en patois bien entendu).
A+
Laurent.
ReM wrote:
Personne ne semble avoir de solution.
OpenOffice sera-t-il plus performant ?
Un dernière p'tit conseil, svp !!!
Ben, si ça ne répond pas dans la commnauté francophone, aller poser la
question à la (plus large) communauté anglophone sur comp.lang.python (en
traduisant la question en patois bien entendu).
Personne ne semble avoir de solution. OpenOffice sera-t-il plus performant ? Un dernière p'tit conseil, svp !!!
Ben, si ça ne répond pas dans la commnauté francophone, aller poser la question à la (plus large) communauté anglophone sur comp.lang.python (en traduisant la question en patois bien entendu).