Tkinter RSS代码在每次更新时都在加速

时间:2019-01-08 18:47:14

标签: python tkinter scroll rss updating

在Google上没有任何帮助,我也问过一些人,但似乎没有人知道如何回答我的问题。

我正在为一个项目编程GUI,它包含一个RSS-Feed代码。 它会滚动浏览新闻,并在更新时(出于明显的调试原因,每3秒更新一次)会加快速度。 这意味着,如果我运行该程序,则两个小时后,行情指示器将以非人类可读的速度滚动。

主要代码不是我写的,我对其进行了修改并添加了更新功能。

main():

import tkinter as tk
from Press import RSSTicker

def displayRSSticker(win):
    # Place RSSTicker portlet
    tickerHandle = RSSTicker(win, bg='black', fg='white', highlightthickness=0, font=("avenir", 30))
    tickerHandle.pack(side='bottom', fill='x', anchor='se')

def main():
    # Set the screen definition, root window initialization
    root = tk.Tk()
    root.configure(background='black')
    width, height = root.winfo_screenwidth(), root.winfo_screenheight()
    root.geometry("%dx%d+0+0" % (width, height))
    label = tk.Label(root, text="Monitor Dashboard", bg='black', fg='red')
    label.pack(side='bottom', fill='x', anchor='se')

    # Display portlet
    displayRSSticker(root)
    # Loop the GUI manager
    root.mainloop(0)

###############################
#     MAIN SCRIPT BODY PART   #
###############################
if __name__ == "__main__":
    main()

RSSTicker类:​​

import feedparser
import tkinter as tk

class RSSTicker(tk.Text):
    # Class constructor
    def __init__(self, parent, **params):
        super().__init__(parent, height=1, wrap="none", state='disabled', **params)
        self.newsFeed = feedparser.parse('http://www.repubblica.it/rss/homepage/rss2.0.xml')
        self.update()

    # Class methods
    def update(self):
        self.headlineIndex = 0
        self.text = ''
        self.pos = 0
        self.after_idle(self.updateHeadline)
        self.after_idle(self.scroll)
        self.after(4000, self.update)

    def updateHeadline(self):
        try:
            self.text += '       ' + self.newsFeed['entries'][self.headlineIndex]['title']
        except IndexError:
            self.headlineIndex = 0
            self.text = self.feed['entries'][self.headlineIndex]['title']

        self.headlineIndex += 1
        self.after(5000, self.updateHeadline)

    def scroll(self):
        self.config(state='normal')
        if self.pos < len(self.text):
            self.insert('end', self.text[self.pos])
        self.pos += 1
        self.see('end')
        self.config(state='disabled')
        self.after(180, self.scroll)

我认为问题出在self.pos变量中,将其打印出来会导致它递增计数,重置为1并递增计数。.但这似乎不是导致股票行情加速的问题。 据我了解,问题一定出在滚动方法中。

如果有人了解如何在更新时保持原始滚动速度,谢谢。

1 个答案:

答案 0 :(得分:0)

我认为您可以使用几个跟踪变量来确保update仅启动一次循环,然后在下次调用update时将仅运行scroll而无需启动新循环环。同时,如果scroll未调用update,则它将根据需要继续循环。

将您的RSSTicker类更改为以下内容:

class RSSTicker(tk.Text):
    # Class constructor
    def __init__(self, parent, **params):
        self.scroll_started = False # Tracker for first update.
        super().__init__(parent, height=1, wrap="none", state='disabled', **params)
        self.newsFeed = feedparser.parse('http://www.repubblica.it/rss/homepage/rss2.0.xml')
        self.update()

    def update(self):
        self.headlineIndex = 0
        self.text = ''
        self.pos = 0
        self.after_idle(self.updateHeadline)
        self.after_idle(lambda: self.scroll('update'))
        self.after(4000, self.update)

    def updateHeadline(self):
        try:
            self.text += '       ' + self.newsFeed['entries'][self.headlineIndex]['title']
        except IndexError:
            self.headlineIndex = 0
            self.text = self.feed['entries'][self.headlineIndex]['title']

        self.headlineIndex += 1
        self.after(5000, self.updateHeadline)

    def scroll(self, from_after_or_update = 'after'):
        self.config(state='normal')
        if self.pos < len(self.text):
            self.insert('end', self.text[self.pos])
        self.pos += 1
        self.see('end')
        self.config(state='disabled')
        # Check if the loop started by after.
        if from_after_or_update != 'update':
            self.scroll_started = True
            self.after(180, self.scroll)
        # If not started by after check to see if it is the 1st time loop is started by "update".
        elif self.scroll_started is False and from_after_or_update == 'update':
            self.scroll_started = True
            self.after(180, self.scroll)
        # If neither of the above conditions then do not start loop to prevent multiple loops.
        else:
            print("ran scroll method without adding new after loop!")