gpt4 book ai didi

python - Tkinter - 如何将实例变量传递给另一个类?

转载 作者:太空宇宙 更新时间:2023-11-04 02:32:28 25 4
gpt4 key购买 nike

我在谷歌上搜索了很多,但都没有用。上周发布了一个问题,但没有答案,因为它似乎太长了......

希望新问题更清楚。

这只是一小段代码,如果您运行它,您将能够重现该问题。我需要做的基本上是获取用户输入(来自 mainGUI 类的 E1)并将其传递给来自数据库类的 insert() 函数。我尝试添加条目时遇到的错误是:

"self.curs.execute("INSERT INTO diary VALUES (?)", (date))sqlite3.ProgrammingError:提供的绑定(bind)数量不正确。当前语句使用 1,提供 0 个。"

我可以毫无问题地读取数据库。

如有任何帮助,我们将不胜感激。

from tkinter import *
import sqlite3

class mainGUI(object):

def __init__(self,window):

self.window=window

self.E1 = Entry(window)
self.E1.grid(row=1, column=0)
self.EG1 = self.E1.get()

global E4
E4 = Listbox(window)
E4.grid(row=2)

B1 = Button(window, text="Add entry", command=lambda: database.insert(self.EG1))

B1.grid(row=1, column=4)

B2 = Button(window, text="View all", command=database.view_all)
B2.grid(row=2, column=4, sticky="WN")

window.mainloop()

class Database(mainGUI):

def __init__(self, db):
self.conn = sqlite3.connect(db)
self.curs = self.conn.cursor()
self.curs.execute("CREATE TABLE IF NOT EXISTS diary (date TEXT)")
self.conn.commit()

def insert(self,date):
database.add_entry(date)
E4.delete(0, END)
E4.insert(END,(date))

def add_entry(self,date):
self.curs.execute("INSERT INTO diary VALUES (?)", (date))
self.conn.commit()

def view_all(self):
E4.delete(0, END)
self.curs.execute("SELECT * FROM diary")
data = self.curs.fetchall()
for row in data:
E4.insert(END,row)

if __name__ == "__main__":
database = Database("dbase.db")
window=Tk()
gui = mainGUI(window)

最佳答案

如果您正在使用类,则不应使用全局变量。相反,您需要访问对象实例的属性和方法。这意味着创建 E4 作为实例变量,并通过 GUI 类的实例访问它。

此外,您的数据库不应继承mainGUI。那不是应该如何使用继承。

您对数据库进行了编码,因此它需要更改 GUI,这很不寻常。相反,您的 GUI 应该是唯一可以修改 GUI 的东西,而您的数据库应该是唯一可以修改数据库的东西。当GUI需要向数据库发送信息或从数据库获取信息时,它可以调用数据库上的方法。

因此,第一步是将数据库对象传递给您的 mainGUI 类(根据 PEP8,该类应命名为 MainGUI):

class MainGUI(object):
def __init__(self,window, db):
self.window = window
self.db = db
...

接下来,在创建 GUI 时传入数据库对象:

if __name__ == "__main__":   
database = Database("dbase.db")
window=Tk()
gui = MainGUI(window, database)

有了它,您现在可以使用数据库获取和提取数据,并使用 GUI 显示数据。

例如,您的 GUI 应该有“view_all”方法,因为它处理改变 View 。它应该调用数据库的“get_all”方法。通过使用lambda,您的代码将变得更易于阅读、编写和调试。

class mainGUI(object):
def __init__(self,window, db):
...
self.E4 = Listbox(...)
...
B2 = Button(..., command=self.view_all)

def view_all(self):
data = self.db.get_all()
self.E4.delete(0, END)
for row in data:
self.E4.insert(END,row)

最后,在您的 Database 中创建一个 get_all 方法,它除了获取和返回数据外什么都不做:

class MainGUI(object):
def get_all(self):
self.curs.execute("SELECT * FROM diary")
data = self.curs.fetchall()
return data

有了以上所有内容,并在将相同的概念应用到其他方法之后(即:Database 类应该只设置或获取数据),您就有了一个可重用的Database 完全独立于使用它的 GUI 的类。

关于python - Tkinter - 如何将实例变量传递给另一个类?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48858446/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com