IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bibliothèques tierces Python Discussion :

Excel.Application et Windows 7


Sujet :

Bibliothèques tierces Python

  1. #1
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur amateur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Points : 6 789
    Points
    6 789
    Billets dans le blog
    15
    Par défaut Excel.Application et Windows 7
    Bonjour à tous,

    J'essaye de faire tourner un morceau de code fonctionnant parfaitement sous XP sous Seven.
    Ce code utilise win32com.client afin de manipuler un fichier Excel.

    Voici les deux premières lignes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    import win32com.client
     
    excel = win32com.client.Dispatch("Excel.Application")
    À la deuxième ligne l'erreur suivante est générée :
    File "C:\Python32\lib\site-packages\win32com\client\dynamic.py", line 85, in _GetGoodDispatch
    IDispatch = pythoncom.CoCreateInstance(IDispatch, None, clsctx, pythoncom.IID_IDispatch)
    pywintypes.com_error: (-2147221005, 'Chaîne de classe incorrecte', None, None)
    En cherchant un peu je suis tombé sur cette discussion http://www.developpez.net/forums/d89...32com-3ds-max/

    Le problème semble être assez proche. Je me dis donc que la solution aussi, seulement la dernière fois que j'ai fait mumuse avec les clés de registre de mon Win7 cela ma value une réinstalle complète... donc moyen envie de jouer au sorcier.

    Avez vous une idée sur la question ?

    D'avance merci
    Initiation à Qt Quick et QML : Partie 1 - Partie 2
    En cas de besoin, pensez à la
    Mon site et mes tutoriaux sur Developpez.com
    Pas de question technique par MP... Les forums sont là pour ça

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 285
    Points : 36 773
    Points
    36 773
    Par défaut
    Salut

    En gros, c'est la registry com qui n'a pas été renseignée: vous devriez avoir un message d'erreur identique avec un appel Dispatch('no_exists.application').
    Try:
    Excel 2007 and 2010.

    In older versions of Excel, the /Regserver switch was used to write the shell registration for Excel. This was true up to Excel 2003, and was removed in Excel 2007. For Excel 2010 and 2007 you need to run setup/repair (running the Office setup in Repair mode from "Programs and Features", aka "Add/Remove Programs").
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur amateur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Points : 6 789
    Points
    6 789
    Billets dans le blog
    15
    Par défaut
    J'ai lancé une réparation depuis le panneau de config... Aucun changement.

    À noter que je n'ai pas MS Office en version normale. Uniquement la version Strater. Mais dans tous les cas cela ne devrait pas poser de souci, puisque cette façon de faire pour gérer les .xls ne nécessite pas Excel d'installé.
    Initiation à Qt Quick et QML : Partie 1 - Partie 2
    En cas de besoin, pensez à la
    Mon site et mes tutoriaux sur Developpez.com
    Pas de question technique par MP... Les forums sont là pour ça

  4. #4
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 285
    Points : 36 773
    Points
    36 773
    Par défaut
    Citation Envoyé par cegDv Voir le message
    À noter que je n'ai pas MS Office en version normale. Uniquement la version Strater. Mais dans tous les cas cela ne devrait pas poser de souci, puisque cette façon de faire pour gérer les .xls ne nécessite pas Excel d'installé.
    Si Excel n'a pas été installé pourquoi espérer que Dispatch("Excel.Application") le trouve?
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  5. #5
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur amateur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Points : 6 789
    Points
    6 789
    Billets dans le blog
    15
    Par défaut
    Et bien il me semble avoir fait des tests où Excel n'était pas présent mais où le programme fonctionnait bien.
    Maintenant, j'ai bien excel, mais en version Starter 2010. La réparation n'y a rien fait, donc peut être une incompatibilité entre win32com et Seven ?
    Initiation à Qt Quick et QML : Partie 1 - Partie 2
    En cas de besoin, pensez à la
    Mon site et mes tutoriaux sur Developpez.com
    Pas de question technique par MP... Les forums sont là pour ça

  6. #6
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 285
    Points : 36 773
    Points
    36 773
    Par défaut
    Citation Envoyé par cegDv Voir le message
    La réparation n'y a rien fait, donc peut être une incompatibilité entre win32com et Seven ?
    J'utilise win32com sur windows7 et avec un Excel "normal" çà fonctionne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    >>> import platform
    >>> platform.uname()
    ('Windows', '****', '7', '6.1.7600', 'AMD64', 'Intel64 Family 6 Model 15 S
    tepping 11, GenuineIntel')
    >>> from win32com.client import Dispatch
    >>> xl = Dispatch('Excel.Application')
    >>> xl
    <COMObject Excel.Application>
    >>> xl.Version
    u'12.0'
    Mais que cela fonctionne chez moi ne nous aide pas trop à trouver ce qui ne va pas chez vous, sinon qu'il n'y a pas de "bug" rendant complètement inutilisable la stack windows7, python win32com, Excel...
    note: si çà ne marchait pas vous trouveriez des plaintes via Google, mais çà peut faire du bien de s'en assurer...

    Et bien il me semble avoir fait des tests où Excel n'était pas présent mais où le programme fonctionnait bien.
    Maintenant, j'ai bien excel, mais en version Starter 2010.
    Vu que çà ne passe pas Dispatch("Excel.Application"), Excel doit être installé et vos souvenirs ne valent pas cahier de tests.

    En supposant que l'Excel version Starter 2010 expose une API COM, pas évident, que son nom soit "Excel.Application" - il ne semble pas interdit d'installer les deux versions sur son PC et de les faire fonctionner indépendamment => des noms "différents".

    Là, pour le coup, il faut aller lire dans la registry.
    Mais je ne suis pas sûr que le forum Python soit le plus indiqué pour trouver de l'aide et des gens qui savent.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  7. #7
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur amateur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Points : 6 789
    Points
    6 789
    Billets dans le blog
    15
    Par défaut
    Merci pour ce test.
    Je n'ai pas eu l'occasion de mon coté de refaire un test sous XP sans Excel, mais il clair qu'il n'y a pas d'incompatibilité en win32com et Win 7.

    Du coup, comme vous le suggéré et comme je l'avais prévu, je vais aller faire un petit tour du coté du forum Windows.

    Encore merci.


    PS: Je passe ce sujet en Résolu et viendrai poster la solution éventuelle pour faire fonctionner win32com avec Excel Starter.
    Initiation à Qt Quick et QML : Partie 1 - Partie 2
    En cas de besoin, pensez à la
    Mon site et mes tutoriaux sur Developpez.com
    Pas de question technique par MP... Les forums sont là pour ça

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 6
    Dernier message: 03/06/2014, 10h09
  2. [WD-2007] Problème CreateObject("Excel.Application") Windows 7
    Par Isa31 dans le forum VBA Word
    Réponses: 13
    Dernier message: 09/07/2012, 14h17
  3. Controle d'applications sous Windows
    Par BNS dans le forum Windows
    Réponses: 2
    Dernier message: 07/04/2006, 13h59
  4. Liste des programme ou applications sous windows xp
    Par bob40 dans le forum Windows XP
    Réponses: 1
    Dernier message: 12/01/2006, 02h14
  5. fermeture de l'application par windows
    Par gudul dans le forum Langage
    Réponses: 3
    Dernier message: 26/08/2005, 17h34

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo