如何在两个函数 Tkinter python 中使用 root.after
How to use root.after in two function Tkinter python
我有下面的代码,问题是当我选择“华氏温度”时,它 运行 是第二个功能然后它返回并且 运行 第一个功能也是如此。如果满足条件,我希望它 运行 一个函数 我认为 root.after 是导致问题的原因,但我不确定如何解决它。
我正在使用这个脚本来显示我的服务器的温度并定期更新它,我想创建一个 drop 来将值从摄氏度更改为华氏度。
from tkinter import *
import paramiko
root = Tk()
root.title('Raspberry Temperature')
root.geometry("250x250")
lab = Label(root)
lab.pack(pady=10)
lab.place(x=140, y=15)
label1 = Label(root, text="Core Temperature :", font=('Segoe', 10))
label1.pack(pady=10)
label1.place(x=20, y=15)
def temperature():
global after_id
p = paramiko.SSHClient()
p.set_missing_host_key_policy(
paramiko.AutoAddPolicy())
p.connect("pi", port=22, username="user", password="pass")
stdin, stdout, stderr = p.exec_command("vcgencmd measure_temp")
opt = stdout.readlines()
opt = "".join(opt)
print(opt)
lab.config(text=opt, font=('Segoe', 11, 'bold'))
after_id = root.after(1000, temperature)
return after_id
def temperature2():
global after_id
p2 = paramiko.SSHClient()
p2.set_missing_host_key_policy(
paramiko.AutoAddPolicy()) # This script doesn't work for me unless this line is added!
p2.connect("pi", port=22, username="user", password="pass")
stdin, stdout, stderr = p2.exec_command("vcgencmd measure_temp")
opt2 = stdout.readlines()
opt2 = "".join(opt2)
print(opt2)
lab.config(text=(opt2,"temp2"), font=('Segoe', 11, 'bold'))
#
after_id = root.after(1000, temperature2)
return after_id
import tkinter as tk
OptionList = [
"fahrenheit",
]
variable = tk.StringVar(root)
variable.set(OptionList[0])
opt = tk.OptionMenu(root, variable, *OptionList)
opt.config(width=10, font=('Helvetica', 12))
opt.pack(side="top")
opt.place(x= 10,y=50)
labelTest = tk.Label(text="", font=('Helvetica', 12), fg='red')
labelTest.pack(side="top")
temperature()
def callback(*args):
global after_id
after_cancel(after_id)
temperature2()
variable.trace("w", callback)
root.mainloop()
问题是您在一个循环中同时拥有 temperature
和 temperature2
,但您永远不会取消循环。因此,如果您先启动 temperature
循环,然后再启动 temperature2
循环,那么两个循环都将是 运行.
您可以通过保存 after
返回的标识符并使用该标识符调用 after_cancel
来停止现有循环。
在您的情况下,您可能想取消 callback
:
中的现有循环
def callback(*args):
global after_id
after_cancel(after_id)
temperature2()
那么,你也要记得初始化after_id
。例如:
def temperature():
global after_id
...
after_id = root.after(1000, temperature)
当然,您可能需要添加一些代码来处理 after_id 未定义或调用 after_cancel
失败的情况。然而,底线是您需要在开始新循环之前停止任何现有循环。
我有下面的代码,问题是当我选择“华氏温度”时,它 运行 是第二个功能然后它返回并且 运行 第一个功能也是如此。如果满足条件,我希望它 运行 一个函数 我认为 root.after 是导致问题的原因,但我不确定如何解决它。
我正在使用这个脚本来显示我的服务器的温度并定期更新它,我想创建一个 drop 来将值从摄氏度更改为华氏度。
from tkinter import *
import paramiko
root = Tk()
root.title('Raspberry Temperature')
root.geometry("250x250")
lab = Label(root)
lab.pack(pady=10)
lab.place(x=140, y=15)
label1 = Label(root, text="Core Temperature :", font=('Segoe', 10))
label1.pack(pady=10)
label1.place(x=20, y=15)
def temperature():
global after_id
p = paramiko.SSHClient()
p.set_missing_host_key_policy(
paramiko.AutoAddPolicy())
p.connect("pi", port=22, username="user", password="pass")
stdin, stdout, stderr = p.exec_command("vcgencmd measure_temp")
opt = stdout.readlines()
opt = "".join(opt)
print(opt)
lab.config(text=opt, font=('Segoe', 11, 'bold'))
after_id = root.after(1000, temperature)
return after_id
def temperature2():
global after_id
p2 = paramiko.SSHClient()
p2.set_missing_host_key_policy(
paramiko.AutoAddPolicy()) # This script doesn't work for me unless this line is added!
p2.connect("pi", port=22, username="user", password="pass")
stdin, stdout, stderr = p2.exec_command("vcgencmd measure_temp")
opt2 = stdout.readlines()
opt2 = "".join(opt2)
print(opt2)
lab.config(text=(opt2,"temp2"), font=('Segoe', 11, 'bold'))
#
after_id = root.after(1000, temperature2)
return after_id
import tkinter as tk
OptionList = [
"fahrenheit",
]
variable = tk.StringVar(root)
variable.set(OptionList[0])
opt = tk.OptionMenu(root, variable, *OptionList)
opt.config(width=10, font=('Helvetica', 12))
opt.pack(side="top")
opt.place(x= 10,y=50)
labelTest = tk.Label(text="", font=('Helvetica', 12), fg='red')
labelTest.pack(side="top")
temperature()
def callback(*args):
global after_id
after_cancel(after_id)
temperature2()
variable.trace("w", callback)
root.mainloop()
问题是您在一个循环中同时拥有 temperature
和 temperature2
,但您永远不会取消循环。因此,如果您先启动 temperature
循环,然后再启动 temperature2
循环,那么两个循环都将是 运行.
您可以通过保存 after
返回的标识符并使用该标识符调用 after_cancel
来停止现有循环。
在您的情况下,您可能想取消 callback
:
def callback(*args):
global after_id
after_cancel(after_id)
temperature2()
那么,你也要记得初始化after_id
。例如:
def temperature():
global after_id
...
after_id = root.after(1000, temperature)
当然,您可能需要添加一些代码来处理 after_id 未定义或调用 after_cancel
失败的情况。然而,底线是您需要在开始新循环之前停止任何现有循环。