Итак, сегодня я впервые попытался использовать классы Python, чтобы удалить чрезмерное использование глобального ключевого слова. Я пытаюсь создать окно tkinter, в котором, когда мы нажимаем одну кнопку, он удаляет нажатую кнопку и заменяет ее новой кнопкой. И когда мы нажимаем ее снова, она удаляет эту кнопку и заменяет старую (первую) кнопку, и это должно повторяться...
Это мой код, который я сделал:
# ================= Importing Modules ===================
from tkinter import *
import tkinter as tk
# ====================================================
class Test():
# ============= Play Button Click =============
def fun1(self):
self.hi.destroy()
self.he.place(x=350,y=340)
# ============ Pause Button Click =============
def fun2(self):
self.he.destroy()
self.hi.place(x=350,y=340)
# ============ Player Window ================
def __init__(self):
self.root = Tk()
self.root.geometry('700x400')
self.root.resizable(0,0)
self.root["bg"] = "black"
self.hi = tk.Button(self.root, text="button 1", bg="white", bd=0, command=lambda: self.fun1() , relief=RIDGE)
self.hi.place(x=350,y=340)
self.he = tk.Button(self.root, text="button 2", bg="white", bd=0, command=lambda: self.fun2() , relief=RIDGE)
self.root.mainloop()
# ============== Calling ===========
if __name__ == '__main__':
Test()
Но вместо желаемого вывода, к сожалению, я получил эту ошибку:
Exception in Tkinter callback
Traceback (most recent call last):
File "C:\Program Files\Python310\lib\tkinter\__init__.py", line 1921, in __call__
return self.func(*args)
File "C:/XXX/XXX/Desktop/test.py", line 29, in <lambda>
self.he = tk.Button(self.root, text="button 2", bg="white", bd=0, command=lambda: self.fun2() , relief=RIDGE)
File "C:/XXX/XXX/Desktop/test.py", line 16, in fun2
self.hi.place(x=350,y=340)
File "C:\Program Files\Python310\lib\tkinter\__init__.py", line 2477, in place_configure
self.tk.call(
_tkinter.TclError: bad window path name ".!button"
ТАК МОЙ ВОПРОС:
doubt1 = Any idea what I am doing wrong?
doubt2 = Or isn't this possible?
if doubt1 or doubt2:
Please explain it...
elif:
Please tell me a better alternative or idea, how to do this efficiently.
else:
Note: I have researched so many questions. Nothing helped me out. Especially ---|
↓
ㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤВот этот.
Вы уничтожаете self.hi
, а затем пытаетесь вызвать place
на уничтоженной кнопке. После того, как виджет был уничтожен, вы больше не можете его использовать.
Если вы хотите продолжать циклически нажимать кнопки, не уничтожайте их. Поскольку вы используете place
, вы можете использовать self.hi.place_forget()
и self.he.place_forget()
, чтобы удалить кнопки из поля зрения, не уничтожая их.
О, лол, это было так просто! Большое спасибо.