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 :

Import module perso bug en tache planifié, alors que OK sous PySripter


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Géomaticien (plutôt sur Arcgis...)
    Inscrit en
    Juillet 2013
    Messages
    49
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Vosges (Lorraine)

    Informations professionnelles :
    Activité : Géomaticien (plutôt sur Arcgis...)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Juillet 2013
    Messages : 49
    Par défaut Import module perso bug en tache planifié, alors que OK sous PySripter
    Bonjour,

    Je suis sous python 2.7, car cela m'est imposé par l'éditeur de mon logiciel principal.
    Je n'ai jamais vraiment créer de programme, mais juste des scripts, que je lance directement dans Pyscripter au besoin, pour m'aider dans mes tâches quotidiennes.

    J'ai aussi des tâches planifiées, qui lance des scripts python, de traitement de mes données géographiques en nocturne .
    Mais jusqu'à présent, tout était écrit dans 1 seul fichier .py.

    Cette fois, j'ai constitué des modules perso, car je les appels plusieurs fois dans des scripts différents.
    Mes modules sont tous dans un sous-dossier, lui-même dans le dossier parent contenant mon script principal.
    Le sous-dossier contient bien un fichier __init__.py

    Je les appels de la façon suivante;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    chemin_mes_modules =r"\\SRV_FICHIERS\Sharedfolders\...\Python_2\Mes_modules_py2"
     
    import sys
    sys.path.insert(0,chemin_mes_modules )
    from Mes_modules_py2 import ODBC_select as sql
    Lorsque je lance mon code via pyscripter, c'est parfait tout fonctionne.

    Puis je fait un petit fichier bat, pour mettre le lancement de mon script principal, en tâche planifiée windows, car j'ai besoin de le faire fonctionner toutes les 20 minutes. Dans mon bat, j'écris;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    c:\Python27\ArcGIS10.7\python.exe "\\SRV_FICHIERS\Sharedfolders\...\Monscript_principal.py" >> "\\SRV_FICHIERS\Sharedfolders\...\log\Log_Monscript_principal_%date:/=-%.txt"
    Là, dans mon fichier de log remonte que mon module ODBC_select est introuvable.

    Si j'ajoute un print dans mon log Je retrouve bien mon chemin; ['\\\\SRV_FICHIERS\\Sharedfolders\\...\\Python_2\\Mes_modules_py2',...

    Je me comprend vraiment pas pourquoi cette erreur, alors que dans pyscripter ça fonctionne parfaitement. Je ne comprend pas pourquoi cette différence entre pyscripter et le lancement dans ma tache planifiée.

    Quelqu'un aurais-t-il une idée svp? Merci

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 741
    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 741
    Par défaut
    Salut,

    Créez un terminal et lancez le .bat directement pour voir s'il fonctionne dans ce contexte/environnement là.

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

  3. #3
    Membre averti
    Homme Profil pro
    Géomaticien (plutôt sur Arcgis...)
    Inscrit en
    Juillet 2013
    Messages
    49
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Vosges (Lorraine)

    Informations professionnelles :
    Activité : Géomaticien (plutôt sur Arcgis...)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Juillet 2013
    Messages : 49
    Par défaut
    J'ai ouvert un terminal cmd, puis naviguer jusqu'à l'emplacement de mon bat.
    Je lance mon bat, mais résultat identique...
    mes modules sont introuvables...

  4. #4
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 741
    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 741
    Par défaut
    Salut,

    Depuis le terminal, lancez l'interpréteur Python et vérifiez que le chemin est "bon" en essayant d'ouvrir le fichier/script avec "open".

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

  5. #5
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 741
    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 741
    Par défaut
    Salut,

    Depuis le terminal, lancez l'interpréteur Python et vérifiez que le chemin est "bon" en essayant d'ouvrir le fichier/script avec "open".
    Réciproquement, sous PyCharm, affichez répertoire du module via:
    print sql.__file__

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

  6. #6
    Membre Expert

    Homme Profil pro
    Ingénieur calcul scientifique
    Inscrit en
    Mars 2013
    Messages
    1 229
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur calcul scientifique

    Informations forums :
    Inscription : Mars 2013
    Messages : 1 229
    Par défaut
    pyscripter, comme tous les autres IDE, rajoute certainement un dossier de plus au path : le dossier courant, dénommé par '.'.

    Faites afficher le path aussi lorsque vous lancez avec pyscripter, de sorte à pouvoir comparer les path (comparer la liste entière, et pas juste vérifier que ce que vous avez ajouté est bien là).
    Et ensuite comme le .bat n'est peut etre pas dans le meme dossier que votre .py principal, et bien le dossier courant n'est pas le meme.

  7. #7
    Membre averti
    Homme Profil pro
    Géomaticien (plutôt sur Arcgis...)
    Inscrit en
    Juillet 2013
    Messages
    49
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Vosges (Lorraine)

    Informations professionnelles :
    Activité : Géomaticien (plutôt sur Arcgis...)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Juillet 2013
    Messages : 49
    Par défaut
    C'est bon j'ai trouvé. Mauvaise route de diagnostic...
    Après x versions, j'ai réussi à avoir un nouveau code d'erreur, dans le batch, le bon vieux "UnicodeEncodeError: 'ascii' codec can't encode characters in position ..."
    Là d'un coup, je me sent comme un bleu...

    Et oui un bon vieil accent à la noix, qui traine dans un print de vérification, alors que tout le reste (dont mon appel du module) est parfaitement bon!
    mes entêtes python sont tous en # -*- coding: cp1252 -*- (soit pas de soucis sous Pysripter!), alors que le fichier bat est par défaut en CP-850... Du coup mes print remontent en erreur d'encodage.

    Dans mon bat, pourtant je commencais bien par CHCP 1252. Mais visiblement cela ne suffit pas. J'ai trouvé une autre commande au début du bat qui visiblement fonctionne mieux ; chcp 28591 > nul (ici). Pourquoi..., je n'en ai aucune idée, mais désormais cela fonctionne.

    Merci wiztricks, pour ton aide. "print sql.__file__" , je n'y avais pas pensais et comme il était bon, cela m'a réorienté sur cet autre diagnostic.

Discussions similaires

  1. Présence d'import dans un fichier d'import "Module" perso
    Par cyberclown dans le forum Général Python
    Réponses: 2
    Dernier message: 15/07/2012, 14h39
  2. importer module perso avec python
    Par rom44 dans le forum Général Python
    Réponses: 4
    Dernier message: 03/08/2011, 12h44
  3. Réponses: 5
    Dernier message: 01/12/2008, 17h00
  4. Lancer un module VBA par une tache planifié
    Par gengen dans le forum Access
    Réponses: 9
    Dernier message: 25/04/2006, 16h22
  5. Créer une tache planifié (.bat ou wsh)
    Par BRAUKRIS dans le forum Windows
    Réponses: 4
    Dernier message: 18/03/2004, 17h12

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