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

Python Discussion :

Tuer une procedure d'ouverture Excel


Sujet :

Python

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2016
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Février 2016
    Messages : 28
    Points : 22
    Points
    22
    Par défaut Tuer une procedure d'ouverture Excel
    Bonjour,

    Mon soucis concerne le comportement d'un Add-In Excel qui varie selon la fermeture de ma feuille Excel.
    En gros, lorsque je ferme à la main mon Excel (Clique sur la croix rouge), je n'ai aucun soucis si je lance après pour la première fois mon script Python.
    Mais si je ferme (End process) mon Excel avec le Task Manager, mon Add-In n'est plus fonctionnel losque j'ouvre mon Excel avec le script Python.

    Pour être plus clair, dès que je "kill" une fois mon Excel (de manière automatique ou manuel), l'Add-in ne fonctionne plus par ouverture du script Python. Il faut dans ce cas que je refasse une ouverture manuel.

    => Je souhaiterais donc fermer mon Excel avec le script Python comme si je cliquais sur "la Croix rouge", cela vous semble possible ?

    Voici le script Python:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
     
    import os
    import subprocess
    import time
     
    def f():
    	my_env=os.environ
    	my_env["PATH"] = (...)
    	xlexepath=(...)	
            xlpathprivatebank= (...)
     
    	proc=subprocess.Popen([xlexepath,r'/r',xlpathprivatebank],env=my_env)
    	time.sleep(20)
    	proc.kill()
     
    if __name__ == '__main__':
    f()
    Ici j'utilise la function "kill()", est-il possible de faire autrement ?

    Merci par avance de votre aide,
    Rainmax

  2. #2
    Membre chevronné
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2013
    Messages
    1 608
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 608
    Points : 2 072
    Points
    2 072
    Par défaut
    Je ne sais pas si je réponds à la question :
    Sous Ubuntu, si je veux fermer par exemple le logiciel "texstudio", je peux faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    import os
    os.system("killall texstudio")
    Pas d'aide par mp.

  3. #3
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2016
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Février 2016
    Messages : 28
    Points : 22
    Points
    22
    Par défaut
    Merci pour ta réponse mais je suis sur Windows :/

    Une question qui pourrait me permettre d'avancer: Serait-il possible de parametrer la fonction "kill()" pour qu'elle soit moins violente ?

    Merci par avance pour votre aide,
    Rainmax

  4. #4
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2016
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Février 2016
    Messages : 28
    Points : 22
    Points
    22
    Par défaut
    Des idées svp ?

  5. #5
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 283
    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 283
    Points : 36 770
    Points
    36 770
    Par défaut
    Citation Envoyé par Rainmax Voir le message
    Des idées svp ?
    Comment arrêter proprement un process qui tourne Excel est plutôt une question Excel (.kill fonctionne pour des process "normaux"/"autres").
    Si une telle méthode existe, la coder en Python ne devrait pas être un problème... mais c'est plutôt dans les forums Excel que seront les experts qui savent.

    Une autre façon de poser le problème serait de voir comment avoir un meilleur contrôle d'Excel via un programme (écrit en Python ou autre). Excel étant un objet COM, un meilleur contrôle passe par pywin32... mais c'est un peu plus compliqué.

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

Discussions similaires

  1. Ecrire une procedure dans Excel
    Par helas dans le forum VBA Access
    Réponses: 1
    Dernier message: 18/03/2008, 08h32
  2. lancer une procedure dès l'ouverture du .exe
    Par melles dans le forum Delphi
    Réponses: 6
    Dernier message: 18/03/2007, 13h57
  3. Ouverture d'une table Access depuis Excel
    Par SlySylvain dans le forum Access
    Réponses: 3
    Dernier message: 28/07/2006, 18h36
  4. Ouverture de fichier avec une procedure !!
    Par pinto_armindo dans le forum Langage
    Réponses: 6
    Dernier message: 27/06/2006, 15h44
  5. Réponses: 2
    Dernier message: 14/05/2006, 19h36

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