Tkinter RSS自动售票机每次升级都会加速

2024-04-19 02:10:46 发布

您现在位置:Python中文网/ 问答频道 /正文

谷歌没有帮助,我也问过一些人,但他们似乎都不知道如何回答我的问题。你知道吗

我正在为一个项目编写一个GUI,它包含一个RSS提要。 它滚动浏览新闻,当它更新时(由于明显的调试原因,每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()

RSTICKER类别:

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并且计数更快。。但它似乎没有问题,导致加速的股票。 据我所知,问题一定出在滚动法上。你知道吗

如果有人知道如何保持原来的滚动速度时更新,谢谢。你知道吗


Tags: textposimportselfmaindefroot速度
1条回答
网友
1楼 · 发布于 2024-04-19 02:10:46

我认为可以使用一对跟踪变量来确保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!")

相关问题 更多 >