我google了很多但它没有用。上周发表了一个问题,但没有答案,因为它似乎过于冗长......
希望新问题更加清晰。
这只是代码的一小部分,如果你运行它,你将能够重现这个问题。我需要做的基本上是获取用户输入(来自mainGUI类的E1)并将其传递给Database类的insert()函数。我尝试添加条目时得到的错误是:
“self.curs.execute(”INSERT INTO日记VALUES(?)“,(日期)) sqlite3.ProgrammingError:提供的绑定数量不正确。当前语句使用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)
答案 0 :(得分:2)
如果您正在使用类,则不应使用全局变量。相反,您需要访问对象实例的属性和方法。这意味着创建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”方法,因为它处理更改视图。它应该调用数据库的“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)
最后,在get_all
中创建Database
方法,除了获取并返回数据之外什么都不做:
class MainGUI(object):
def get_all(self):
self.curs.execute("SELECT * FROM diary")
data = self.curs.fetchall()
return data
有了上述所有内容,并且在将相同的概念应用于其他方法之后(即:Database
类应该只设置或获取数据),您有一个完全可重用的Database
类独立于使用它的GUI。
答案 1 :(得分:0)
我注意到的一件事是你没有将任何textvariable
与Entry小部件相关联,因此它将null值传递给另一个类。请尝试将self.EG1
设为textvariable
,然后将其传递给该功能。
self.EG1 = StringVar()
self.E1 = Entry(window,textvariable=self.EG1)
self.E1.grid(row=1, column=0)
B1 = Button(window, text="Add entry", command=lambda: database.insert(self.EG1.get()))