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

Tkinter Python Discussion :

Mise à jour Label par une boucle


Sujet :

Tkinter Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de memento80
    Homme Profil pro
    Boulot : ne rentre pas dans une case
    Inscrit en
    Novembre 2004
    Messages
    163
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Boulot : ne rentre pas dans une case
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2004
    Messages : 163
    Par défaut Mise à jour Label par une boucle
    Bonjour,

    Je fais mes premiers pas avec tkinter et, autant on trouve plein de tutoriels sur Python, autant on (je ?) ne trouve pas grand chose sur tkinter..

    Du coup, j'ai le problème suivant :

    Je lis un fichier CSV et je voudrais modifier le texte du label pour chaque valeur trouvée. Le rafraichissement du Label sera régulé par une temporisation (sleep).

    Pour l'instant, seul la dernière valeur s'affiche dans le Label en toute fin de programme... mais pas les valeurs intermédiaires.

    Merci par avance pour votre aide.

    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
    28
    29
    30
    from tkinter import *
    import csv
    import time
     
    ficCSV = csv.reader(open("log\\ficCSV.csv", "r"), delimiter=';') # Lecture du fichier csv en direct
     
    class liveFen(object):
        def __init__(self):
            self.root = Tk()
            self.texte = StringVar()
            self.lb1 = Label(self.root, textvariable=self.texte)
            self.lb1.grid(row =2, column =1, columnspan =3)
            Button(self.root, text ="Instruction suivante", command =self.evenSuiv).grid(row =3, column =3)        
            self.root.mainloop()
     
        def evenSuiv(self):
            for ligne in ficCSV: # Pour chaque ligne du fichier
                # Initialisation des variables
                tempsEvenement = float(ligne[0])
                numero = ligne[1]
                typeEvenement = ligne[2]
                commentaireEvenement = ligne[3]
                time.sleep(1.500) # Temps attente
                self.texte.set(commentaireEvenement)
     
    def liveGraph():
        """ Affichage en direct par l'intermédiaire de la lecture d'un fichier csv
        """
        tempsEvenementPrecedent = 0.000
        f = liveFen()

  2. #2
    Membre Expert
    Profil pro
    Développeur en systèmes embarqués retraité
    Inscrit en
    Mars 2006
    Messages
    952
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2006
    Messages : 952
    Par défaut
    Salut,

    C'est vraisemblablement parce que ta boucle prend 100% du temps, donc le rafraichissement graphique ne se fait que quand la CPU est libérée. Il faut donc forcer ce rafraichissement dans ta boucle par la méthode update du widget qui t'intéresse.

    vu ici:

    w.update()

    This method forces the updating of the display. It should be used only if you know what you're doing, since it can lead to unpredictable behavior or looping. It should never be called from an event callback or a function that is called from an event callback.

    A+

    Pfeuh

  3. #3
    Membre confirmé Avatar de memento80
    Homme Profil pro
    Boulot : ne rentre pas dans une case
    Inscrit en
    Novembre 2004
    Messages
    163
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Boulot : ne rentre pas dans une case
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2004
    Messages : 163
    Par défaut
    Ah oui ça marche maintenant.
    J'ignorais qu'il fallait forcer quoique ce soit, que le rafraichissement se faisait naturellement... C'est moins intuitif du coup pour un novice tel que moi. Il faut juste le savoir.

    Merci beaucoup.

  4. #4
    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,

    En fait on force la mise à jour de l'affichage car l'interpréteur est occupé.
    Une autre approche:
    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    from tkinter import *
    import csv
     
    class liveFen(object):
        def __init__(self, f, ficCSV):
            self.root = Tk()
            self.fichier = f
            self.ficCSV = ficCSV
            self.lb1 = Label(self.root)
            self.lb1.grid(row=0, column=0, columnspan=3)
            Button(self.root, text="Lire les instructions",
                   command=self.evenSuiv).grid(row=1, column=2)
            self.root.protocol("WM_DELETE_WINDOW", self.on_quit)
            self.root.mainloop()
     
        def evenSuiv(self):
            try:
                ligne = self.ficCSV.__next__()
            except StopIteration:
                self.fichier.close()
                ligne = None
            if ligne:
                # Initialisation des variables
                tempsEvenement = float(ligne[0])
                numero = ligne[1]
                typeEvenement = ligne[2]
                commentaireEvenement = ligne[3]
                self.lb1.config(text = commentaireEvenement)
                #self.root.update()
                self.root.after(1500, self.evenSuiv) # en ms
     
        def on_quit(self):
            self.root.quit()
     
     
    def liveGraph(fichier, ficCSV):
        """ Affichage en direct par l'intermédiaire de la lecture d'un fichier csv
        """
        #tempsEvenementPrecedent = 0.000
        f = liveFen(fichier, ficCSV)
     
    fichier = open("log\\ficCSV.csv", "r")
    ficCSV = csv.reader(fichier, delimiter=';')
    #liveGraph(fichier, ficCSV)
    liveFen(fichier, ficCSV)
    Ou
    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    from tkinter import *
    import csv
     
    class liveFen(Tk):
        def __init__(self, f, ficCSV):
            Tk.__init__(self)
            self.fichier = f
            self.ficCSV = ficCSV
            self.lb1 = Label(self)
            self.lb1.grid(row=0, column=0, columnspan=3)
            Button(self, text="Lire les instructions",
                   command=self.evenSuiv).grid(row=1, column=2)
            self.protocol("WM_DELETE_WINDOW", self.on_quit)
     
        def evenSuiv(self):
            try:
                ligne = self.ficCSV.__next__()
            except StopIteration:
                self.fichier.close()
                ligne = None
            if ligne:
                # Initialisation des variables
                tempsEvenement = float(ligne[0])
                numero = ligne[1]
                typeEvenement = ligne[2]
                commentaireEvenement = ligne[3]
                self.lb1.config(text = commentaireEvenement)
                #self.update()
                self.after(1500, self.evenSuiv) # en ms
     
        def on_quit(self):
            self.quit()
     
     
    def liveGraph(fichier, ficCSV):
        """ Affichage en direct par l'intermédiaire de la lecture d'un fichier csv
        """
        #tempsEvenementPrecedent = 0.000
        f = liveFen(fichier, ficCSV)
        f.mainloop()
     
    if __name__ == "__main__":
        fichier = open("log\\ficCSV.csv", "r")
        ficCSV = csv.reader(fichier, delimiter=';')
        #liveGraph(fichier, ficCSV)
        app = liveFen(fichier, ficCSV)
        app.mainloop()
    @+

  5. #5
    Membre confirmé Avatar de memento80
    Homme Profil pro
    Boulot : ne rentre pas dans une case
    Inscrit en
    Novembre 2004
    Messages
    163
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Boulot : ne rentre pas dans une case
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2004
    Messages : 163
    Par défaut
    Merci pour cette autre solution PauseKawa. Je n'aurais jamais trouvé ça tout seul.
    Elle m'a solutionné un problème du coup que j'avais : je n'avais plus la main sur la fenêtre quand le "sleep" était en exécution. Maintenant que je l'ai, je peux influencer dessus autant que je veux (accélérer, ralentir...).

    Super. J'ai l'impression que je n'étais pas dans le bon le chemin. Espérons que j'y reste maintenant.

    A+

  6. #6
    Membre confirmé Avatar de memento80
    Homme Profil pro
    Boulot : ne rentre pas dans une case
    Inscrit en
    Novembre 2004
    Messages
    163
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Boulot : ne rentre pas dans une case
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2004
    Messages : 163
    Par défaut
    Je suis de nouveau coincé sur mon programme lié à la précédente réponse...

    Avec la solution de PauseKawa, je voudrais passer un argument à ma fonction evenSuiv pour, par exemple, en fonction du bouton sur lequel on clique, il choisit de lire un fichier csv différent.

    Et là... je ne trouve pas la méthode.
    J'ai bien passé avec un lambda l'argument au bouton... mais une fois qu'il arrive à la fonction evenSuiv.. dans la fonction, alors j'ai l'impression qu'il se met à boucler (en tout cas, il ne me rends plus du tout le main jusqu'à figer complètement).

    Comment faire ?
    Merci d'avance.

    Code précédent modifié :
    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    from tkinter import *
    import csv
     
    class liveFen(object):
        def __init__(self, f, ficCSV):
            self.root = Tk()
            self.fichier = f
            self.ficCSV = ficCSV
            self.lb1 = Label(self.root)
            self.lb1.grid(row=0, column=0, columnspan=3)
            Button(self.root, text="Lire les instructions",
                   command=lambda choixFic="A1":self.evenSuiv(choixFic)).grid(row=1, column=2)
            Button(self.root, text="Lire les instructions",
                   command=lambda choixFic="A2":self.evenSuiv(choixFic)).grid(row=2, column=2)
            self.root.protocol("WM_DELETE_WINDOW", self.on_quit)
            self.root.mainloop()
     
        def evenSuiv(self, choixFic):
            try:
                ligne = self.ficCSV.__next__()
            except StopIteration:
                self.fichier.close()
                ligne = None
            if ligne:
                # Initialisation des variables
                tempsEvenement = float(ligne[0])
                numero = ligne[1]
                typeEvenement = ligne[2]
                commentaireEvenement = ligne[3]
                self.lb1.config(text = commentaireEvenement)
                #self.root.update()
                self.root.after(1500, self.evenSuiv(choixFic)) # en ms
     
        def on_quit(self):
            self.root.quit()
     
     
    def liveGraph(fichier, ficCSV):
        """ Affichage en direct par l'intermédiaire de la lecture d'un fichier csv
        """
        #tempsEvenementPrecedent = 0.000
        f = liveFen(fichier, ficCSV)
     
    fichier = open("log\\ficCSV.csv", "r")
    ficCSV = csv.reader(fichier, delimiter=';')
    #liveGraph(fichier, ficCSV)
    liveFen(fichier, ficCSV)

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 03/10/2013, 10h45
  2. Réponses: 4
    Dernier message: 02/06/2008, 14h03
  3. Requête Mise à jour à partir d'une autre table
    Par temar dans le forum Access
    Réponses: 2
    Dernier message: 17/05/2006, 09h23
  4. Mise à jour automatique d'une table access via un .xls
    Par infratunes dans le forum Access
    Réponses: 4
    Dernier message: 05/04/2006, 18h33
  5. [VS2003][VB.NET]Mise à jour DataSet d'une grille (erreur)
    Par m-mas dans le forum Windows Forms
    Réponses: 2
    Dernier message: 08/02/2006, 10h41

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