关于代码的一些描述:
after
方法中尝试了一些不同的间隔值,结果相同。在代码:
from tkinter import *
import os
import tkinter.messagebox as messagebox
import threading
import re
def watch_clipboard(tk,pipeout):
content = ''
last_content = ''
while True:
try:
content = tk.clipboard_get()
except TclError:
pass
result = re.match('http:',content)
if content != last_content:
if result:
last_content = content
message = 'show'.encode()
os.write(pipeout,message)
class GUI:
def __init__(self):
self.tk = Tk()
self.tk.resizable(0, 0)
self.tk.title('watch clipboard')
pipein,pipeout = os.pipe()
threading.Thread(target=watch_clipboard,daemon=True,args=(self.tk,pipeout)).start()
self.tk.after(5000,lambda:self.clipboard_confirm(pipein))
self.tk.mainloop()
def clipboard_confirm(self,pipein):
message = os.read(pipein,16)
if message == b'show':
self.tk.clipboard_clear()
messagebox.askokcancel('', 'add this in?', default='ok')
self.tk.after(5000,clipboard_confirm(pipein)) #add this
if __name__ == '__main__':
gui = GUI()
在编辑:A.罗达斯的代码有用。它似乎多线程导致问题。很深原因不明。在
我认为多线程不是适合您的最佳方法,
after
可能已经足够了。您可以使用较低的超时调用tk.after
,而不是繁忙的等待循环。然后您只需要将watch_clipboard
的逻辑移动到类中,这样就不必担心线程之间的通信了。在这个问题很有可能是因为使用从主线程以外的任何地方调用Tkinter函数的线程可能会导致问题。在
使用线程而不是利用内置的无限循环(事件循环)有什么原因?我建议使用
after
每隔一秒左右检查一下键盘。在@laike9m
你的代码的错误是os.管道使用。
操作系统读取()是一个阻塞函数,它将接收操作系统读取()阻塞一次
clipboard_confirm
运行。导致用户界面卡住。此错误与
after
和多线程无关。在相关问题 更多 >
编程相关推荐