- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在谷歌上搜索了很多,但都没有用。上周发布了一个问题,但没有答案,因为它似乎太长了......
希望新问题更清楚。
这只是一小段代码,如果您运行它,您将能够重现该问题。我需要做的基本上是获取用户输入(来自 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/
在 How to make a Tkinter window jump to the front? 中提出的问题之后的一个问题 我希望有一个顶层窗口(我用它来导航我的其他主窗口)总是在前面。但我希望它
有没有办法在 Tkinter 中保持小部件(特别是图像)的堆叠顺序一致?例如,我可能在 Canvas 上的同一位置有两个矩形、两个三角形和一个圆。圆圈移动到最后一次点击鼠标的地方,但我总是希望它被绘制
这是一个简单的 GUI 程序,用于创建 5x16 按钮矩阵。 from tkinter import * root = Tk() button = [[0 for x in range(16)] fo
有一个错误:“AttributeError: module 'tkinter' has no attribute 'messagebox'” 即使 import tkinter 一开始就已经给出了,为
我知道 menu.tk_popup() 可用于在特定坐标处打开上下文菜单,但也不知道如何从中打开子菜单,如果这有意义的话。这是我编写的代码: import tkinter as tk root = t
我正在尝试在禁用自动换行和水平滚动条的文本窗口中书写,如下所示: root = Toplevel() root.geometry("%dx%d+0+0" % (350,400)) af=Frame(r
已经将文本变量分配给小部件后,如何将其删除? widget.config(textvariable=None)只是不工作。在谷歌或这里找不到任何东西。 最佳答案 将您的变量分配给一个空字符串以实现此目
Jython 支持 Tkinter 吗?如果我用 Python 编写一个程序并放一个 使用 Tkinter 的 GUI 前端,做同样的事情有多难 Jython 中的程序?或者对于 Jython GUI
因此,我尝试创建一个 tkinter 窗口,显示当前时间和日期以及自定义短语。不过,我遇到的问题是,我似乎无法在第二天刷新日期。 我可以传递截至运行代码时的当前日期,但之后它变为静态。 这是我目前的程
我的理解是在初始化 __init__ 中的所有框架和小部件之后方法,tkinter 窗口会调整大小以适合所有这些组件。 我想将窗口的初始化大小设置为其最小大小。我希望能够最大化并放大窗口,但我从不希望
此代码仅水平居中,如何使进度条也垂直居中? import Tkinter import ttk root = Tkinter.Tk() root.geometry("=500x500") root.p
使用 Python 2.7 和 Tkinter 模块,我创建了一个菜单按钮并为其分配了一个菜单。现在每次我在特定位置发布菜单时,菜单的宽度都会根据字符数自动设置。有没有办法在菜单小部件中设置静态宽度?
我想将我的 tkinter 应用程序的主题更改为 clam。 代码是什么,我把它放在哪里?我试过了: from tkinter import * from tkinter.ttk import * s
我有以下代码: from Tkinter import * from urllib import urlretrieve import webbrowser import ttk def get_la
我知道,如果我将滚动条控制的框架绑定(bind)到函数 ( onFrameConfigure ),您可以获得滚动条位置,如下所示:self.calendar_frame.bind("", self.o
许多网站都说菜单小部件有一个选项“字体”,但我一直无法设置它。系统是在 Windows 8.1 中运行的 Python 3.5。脚本开始: 从 tkinter 导入 * 根 = Tk() root.g
我正在阅读本教程,它帮助我同时学习 tkinter 和 wxWidgets,但我想深入挖掘,所以想知道哪个 GUI 工具更适合深入学习,为什么? 最佳答案 不可能说哪个“更好”。两者均可用于最常见的用
看书学python,tkinter.END用在一段代码里不用解释 import tkinter def count(text, out_data): """ Update out_data w
我正在尝试使用 Python 2.7 将 Tkinter 导入到我的项目中,但我收到了错误: ImportError: No module named tkinter 在有人说之前,我已经尝试了“Tk
当我回答 Tkinter 问题时,我通常会尝试自己运行代码,但有时我会收到此错误: Traceback (most recent call last): File "C:\Python27\pyg
我是一名优秀的程序员,十分优秀!