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 :

Programme python tourne régulièrement et enregistre le résultat dans un fichier excel.


Sujet :

Python

  1. #1
    Membre confirmé
    Étudiant
    Inscrit en
    Février 2009
    Messages
    220
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2009
    Messages : 220
    Par défaut Programme python tourne régulièrement et enregistre le résultat dans un fichier excel.
    Bonjour,

    J'ai deux questions... et j'ai besoin vraiment de vos aides parce que je suis débutant en python.

    1/
    J'ai un programme python. Mon but est de le faire tourner régulièrement chaque mois, d'une manière automatique (c'est à dire le programme il se lance automatiquement chaque mois). comment je pourrai faire ça ???

    2/
    Le résultat de l’exécution du programme pour chaque mois donne des compteurs (x, y et z) que je les calculer dans mon programme. Je voudrai enregistrer le résultat de ces compteurs dans un fichier excel ( les colonnes représentent les mois et les lignes se sont mes compteurs ). Comment je pourrai faire ça ???

    Merci beaucoup d'avance.

  2. #2
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Pour le 1: les systèmes d'exploitation ont cette fonction de lancer certains programmes périodiquement: il suffit de l'utiliser pour lancer le programme Python.

    Pour le 2: Certains modules permettent d'écrire directement des fichiers Excel, mais le plus simple est d'écrire des fichiers 'csv' (http://docs.python.org/library/csv.html#module-csv) qui sont faciles à ouvrir avec Excel.

  3. #3
    Membre confirmé
    Étudiant
    Inscrit en
    Février 2009
    Messages
    220
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2009
    Messages : 220
    Par défaut
    Merci pour votre réponse, mais elle n'est pas trop claire

    Je travail sous ubuntu et chaque mois le programme doit être lancer automatiquement et puis il enregistre le résultat trouvé dans la colonne appropriée, à partir de tous ces résultats je vais générer des courbes, je ne sais pas si les fichiers csv permettent de faire ça ??

    C'est ça mon but..

  4. #4
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Sous Ubuntu, le logiciel qui permet de lancer des tâches périodiques s'appelle "cron". Si le PC ne tourne pas tout le temps, il vaut mieux utiliser "anacron". Et si tu veux piloter "anacron" en graphique, il y a "gnome-schedule". Tu trouveras la doc chez Ubuntu (http://doc.ubuntu-fr.org/gnome-schedule)

    Pour csv, je ne vois pas le problème: c'est un fichier texte. Le mois suivant, ton programme lancé par anacron lit le fichier csv précédent en le transformant en liste de listes, ajoute le nouveau mois comme une colonne supplémentaire avec toutes les valeurs des capteurs sur toutes les lignes, et réécrit le fichier. Ce fichier csv sera ouvert sans problème sous Excel pour tracer les courbes.

    Si tu veux plus d'aide, il faut raisonner sur un cas concret simplifié.

  5. #5
    Membre confirmé
    Étudiant
    Inscrit en
    Février 2009
    Messages
    220
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2009
    Messages : 220
    Par défaut
    Bonjour,

    Merci pou vos propositions. En fait, j'ai chercher un peu sur les fichier csv et j'ai trouvé un simple exemple http://www.developpez.net/forums/d77...-python-3-1-a/ et il m'a bien aidé pour comprendre ce type de fichier et sa liaison avec les fichier excel.

    Pour mon exemple, je doit obtenir comme résultat ce qui est illustré dans la capture ci-jointe et j'ai deux questions :
    1- C'est quoi la fonction qui permet d'ajouter les colonnes et non pas les lignes comme liste (writerow : c'est pour les lignes)
    2- Comment je pourrai savoir le mois suivant, pour insérer dans l’exécution suivante ['Septembre', 'resultat2X', 'resultat2Y', 'resultat2Z'], sachant que les résultats doivent être des entiers pour faire ensuite mes calcule pour la génération des courbes.

    Merci beaucoup d'avance..
    Images attachées Images attachées  

  6. #6
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Admettons que le fichier csv, appelé 'fichier.csv', mis à jour le mois précédent contienne:

    ;Aout;Septembre
    CompteurX;50;47
    CompteurY;35;39
    CompteurZ;12;18
    On veut ajouter la colonne: ["Octobre", 45, 41, 21]

    1- lire le fichier csv:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    import csv
     
    with open('fichier.csv', 'rb') as f:
        fcsv = csv.reader(f, delimiter=';', dialect=csv.excel)
        tableau = []
        for ligne in fcsv:
            tableau.append(ligne)
    La variable tableau contient alors (c'est la liste des lignes):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    [['', 'Aout', 'Septembre'], ['CompteurX', '50', '47'], ['CompteurY', '35', '39'], ['CompteurZ', '12', '18']]
    2- on ajoute le mois suivant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    nouvmois =  ["Octobre", 45, 41, 21]
    for i in xrange(0, len(tableau)):
        tableau[i].append("%s" % nouvmois[i])
    tableau contient alors:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    [['', 'Aout', 'Septembre', 'Octobre'], ['CompteurX', '50', '47', '45'], ['CompteurY', '35', '39', '41'], ['CompteurZ', '12', '18', '21']]
    3- écrire le nouveau fichier ainsi mis à jour:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    with open('fichier.csv', 'wb') as f:
        fcsv = csv.writer(f, delimiter=';', dialect=csv.excel) 
        for ligne in tableau:
            fcsv.writerow(ligne)
    Le nouveau fichier contient alors:

    ;Aout;Septembre;Octobre
    CompteurX;50;47;45
    CompteurY;35;39;41
    CompteurZ;12;18;21
    Sous Windows, un simple double-clic ouvre ce fichier sous Excel. Mais s'il faut travailler dessus, il faudra probablement l'ouvrir en tant que tableau dans un classeur.

    A noter qu'Excel reconnait automatiquement les nombres entiers, même quand ils sont envoyés sous forme de chaines: ils se calent à droite de la colonne alors que les chaines se calent à gauche. C'est vrai aussi pour les nombres flottants, à condition de les envoyer sous forme de chaines avec une virgule décimale au lieu du point.

    Ok?

  7. #7
    Membre confirmé
    Étudiant
    Inscrit en
    Février 2009
    Messages
    220
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2009
    Messages : 220
    Par défaut
    Bonjour,

    Merci beaucoup pour votre aide

    Une petite question: Il n'y a pas une fonction en python qui permet de détecter le mois actuel (à partir de la date actuelle) lors de l’exécution du programme ??
    Parce que c'est plus mieux que de taper "octobre" manuellement.

  8. #8
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Citation Envoyé par ysahel Voir le message
    détecter le mois actuel (à partir de la date actuelle) lors de l’exécution du programme ??
    A condition qu'on soit effectivement dans le mois en question, puisqu'on utilise la date de l'ordinateur:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    import datetime
     
    mois = ['janvier', 'fevrier', 'mars', 'avril', 'mai', 'juin', 'juillet', 'aout',
            'septembre', 'octobre', 'novembre', 'decembre']
     
    print mois[datetime.datetime.now().month-1]
    aout
    Compte tenu de ton application (Ubuntu <=> Excel sous Windows), je te déconseille de mettre les accents pour les mois qui en ont (février, août, décembre), car cela pourrait donner des problèmes d'encodage.

  9. #9
    Membre confirmé
    Étudiant
    Inscrit en
    Février 2009
    Messages
    220
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2009
    Messages : 220
    Par défaut copier-coller un fichier dans un autre dossier
    Merci beaucoup tyrtamos le problème est résolu

    J'ai une autre petite question en ce qui concerne python en général
    Si j'ai un fichier texte et je voudrai faire une copie de ce fichier dans un autre dossier. Est ce que je dois lire le fichier et puis écrire dans le nouvel fichier ( dans le deuxième dossier) ou bien il y a une autre fonction plus simple en python qui permet de faire directement le copier/coller de ce fichier dans un autre emplacement.

    Merci beaucoup d'avance

  10. #10
    Expert confirmé
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    4 064
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4 064
    Par défaut
    Le module shutil est fait pour ça

  11. #11
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Citation Envoyé par fred1599 Voir le message
    Le module shutil est fait pour ça
    +1

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    shutil.copy(source, destination)

  12. #12
    Membre confirmé
    Étudiant
    Inscrit en
    Février 2009
    Messages
    220
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2009
    Messages : 220
    Par défaut
    Merci beaucoup pour vous,

    J'ai fait le copie de mes fichier
    mais comme je travail sous ubuntu, malheureusement il y a un cadena sur chaque fichier donc seulement le root il peut ouvrir les fichiers copiés, est ce qu'il y a une solution pour ça ??

  13. #13
    Membre Expert Avatar de PauseKawa
    Homme Profil pro
    Technicien Help Desk, maintenance, réseau, système et +
    Inscrit en
    Juin 2006
    Messages
    2 725
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Technicien Help Desk, maintenance, réseau, système et +
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 725
    Par défaut
    Bonjour,

    Le module os permets de changer les droits/l'utilisateur d'un fichier.

    @+

  14. #14
    Membre Expert Avatar de plxpy
    Homme Profil pro
    Ingénieur géographe
    Inscrit en
    Janvier 2009
    Messages
    792
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur géographe
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2009
    Messages : 792
    Par défaut
    Bonjour

    Avant de "réparer" les droits et autre propriétaire, pourquoi diable les fichiers copiés sont-ils affublés d'un petit cadenas dans le file manager (alors que, sauf à le faire exprès, ça ne devrait pas être le cas)

    À qui appartiennent-ils ? Quels sont les droits associés ("ls -l" dans une fenêtre terminal) ? Comment sont-ils copiés et, surtout, par quel utilisateur ? root ? un utilisateur lambda ? résultat d'une exécution de cron ?

  15. #15
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Citation Envoyé par ysahel Voir le message
    malheureusement il y a un cadena sur chaque fichier donc seulement le root il peut ouvrir les fichiers copiés, est ce qu'il y a une solution pour ça ??
    Bizarre: ce n'est pas parce que le fichier appartient à root que tu ne peux pas le lire. Peux-tu donner les droits exacts du fichier avec le propriétaire (genre: "rw-r--r--" propriétaire=root, groupe=root)? A noter que pour copier un fichier root, il suffit de pouvoir le lire, et la copie t'appartiendra. Et puis sous Ubuntu, une fois le système lancé par root, on ne travaille pas sous root mais sous le super-administrateur qui est au départ l'utilisateur qui a installé l'OS.

    Sinon, en plus de la solution de PauseKawa, tu peux essayer de lancer ton programme Python avec "sudo python tonprogramme.py", mais il vaudrait mieux comprendre un peu mieux le problème...

  16. #16
    Membre Expert Avatar de PauseKawa
    Homme Profil pro
    Technicien Help Desk, maintenance, réseau, système et +
    Inscrit en
    Juin 2006
    Messages
    2 725
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Technicien Help Desk, maintenance, réseau, système et +
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 725
    Par défaut
    Bonjour,

    Pour les droits cela viens de là:
    Citation Envoyé par tyrtamos Voir le message
    Sous Ubuntu, le logiciel qui permet de lancer des tâches périodiques s'appelle "cron". Si le PC ne tourne pas tout le temps, il vaut mieux utiliser "anacron". Et si tu veux piloter "anacron" en graphique, il y a "gnome-schedule". Tu trouveras la doc chez Ubuntu (http://doc.ubuntu-fr.org/gnome-schedule)
    @

  17. #17
    Membre Expert Avatar de PauseKawa
    Homme Profil pro
    Technicien Help Desk, maintenance, réseau, système et +
    Inscrit en
    Juin 2006
    Messages
    2 725
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Technicien Help Desk, maintenance, réseau, système et +
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 725
    Par défaut
    Citation Envoyé par tyrtamos Voir le message
    A noter que pour copier un fichier root, il suffit de pouvoir le lire, et la copie t'appartiendra.
    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    def copyfileobj(fsrc, fdst, length=16*1024):
        """copy data from file-like object fsrc to file-like object fdst"""
        while 1:
            buf = fsrc.read(length)
            if not buf:
                break
            fdst.write(buf)
    ....
    def copyfile(src, dst):
        """Copy data from src to dst"""
        if _samefile(src, dst):
            raise Error("`%s` and `%s` are the same file" % (src, dst))
     
        for fn in [src, dst]:
            try:
                st = os.stat(fn)
            except OSError:
                # File most likely does not exist
                pass
            else:
                # XXX What about other special files? (sockets, devices...)
                if stat.S_ISFIFO(st.st_mode):
                    raise SpecialFileError("`%s` is a named pipe" % fn)
     
        with open(src, 'rb') as fsrc:
            with open(dst, 'wb') as fdst:
                copyfileobj(fsrc, fdst)
    copyfile est sans doute préférable à
    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
    def copymode(src, dst):
        """Copy mode bits from src to dst"""
        if hasattr(os, 'chmod'):
            st = os.stat(src)
            mode = stat.S_IMODE(st.st_mode)
            os.chmod(dst, mode)
    ...
    def copy(src, dst):
        """Copy data and mode bits ("cp src dst").
     
        The destination may be a directory.
     
        """
        if os.path.isdir(dst):
            dst = os.path.join(dst, os.path.basename(src))
        copyfile(src, dst)
        copymode(src, dst)

  18. #18
    Membre Expert Avatar de plxpy
    Homme Profil pro
    Ingénieur géographe
    Inscrit en
    Janvier 2009
    Messages
    792
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur géographe
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2009
    Messages : 792
    Par défaut
    Lancer des taches via cron ou anacron peut être fait par un autre utilisateur que root.

    Sur certains systèmes (je ne peux pas le tester car je ne dispose actuellement que d'une tablette), il faut peut-être, mais une bonne fois pour toute, autoriser tel ou tel utilisateur à pouvoir utiliser cron/anacron mais c'est possible (et souhaitable ici).

    De mémoire, fichiers cron.deny et/ou cron.allow

    Et après, tout (les droits) rentrera dans l'ordre.

  19. #19
    Membre Expert Avatar de PauseKawa
    Homme Profil pro
    Technicien Help Desk, maintenance, réseau, système et +
    Inscrit en
    Juin 2006
    Messages
    2 725
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Technicien Help Desk, maintenance, réseau, système et +
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 725
    Par défaut
    Petite question: Pourquoi ne pas avoir proposer xlrd/xlrw ?

  20. #20
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Bonjour PauseKawa,

    Citation Envoyé par PauseKawa Voir le message
    Petite question: Pourquoi ne pas avoir proposer xlrd/xlrw ?
    Parce que je ne connais pas assez ces modules, mais que j'utilise souvent csv.

    Par ailleurs, xlrd semble lire mais pas écrire, et je ne trouve pas xlrw. Et xlrd semble limité à Excel 2003 pour l'instant ("Support for Excel 2007 XML files is on the way."). Par contre, xlrd est bien disponible sous Ubuntu (python-xlrd).

    Bref: je suis sûr que csv répond au problème posé. Pour les autres solutions: tu peux proposer, ça m’intéresse aussi!

    [Edit] il n'y a pas xlrw, mais xlwt qui peut fabriquer du fichier Excel, et ça existe sous Ubuntu (python-xlwt). Il y a aussi python-openpyxl qui peut lire/écrire des fichiers Excel 2007 XML.

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Réponses: 3
    Dernier message: 12/05/2015, 14h26
  2. Enregistrer des donneés dans un fichier EXCEL
    Par waelamor dans le forum VB.NET
    Réponses: 3
    Dernier message: 13/08/2013, 22h16
  3. [Débutant] Enregistrer des données dans un fichier Excel
    Par ezzou1 dans le forum Interfaces Graphiques
    Réponses: 5
    Dernier message: 10/05/2012, 19h30
  4. résultats dans un fichier excel
    Par Mazola dans le forum Documents
    Réponses: 1
    Dernier message: 20/09/2008, 10h05
  5. Enregistrer le résultat d'une requête dans un fichier Excel
    Par Isa31 dans le forum Bases de données
    Réponses: 4
    Dernier message: 24/05/2005, 14h31

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