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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  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 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)
    @

  8. #8
    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.

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

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