- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个 tkinter 框架页面,其中包含用于输入客户详细信息的姓名和地址的文本框。同一页面还有一个保存按钮,该按钮链接到另一个方法,该方法将文本框中的详细信息保存到 .sqlite 数据库。但是,当我单击按钮时,它显示“sqlite3.InterfaceError:绑定(bind)参数 1 错误 - 可能不受支持的类型。”这是一个不言自明的错误,但我不知道将输入更改为正确的输入。拜托,任何帮助都会很棒,谢谢!
tk 帧间和页面布局 + 保存按钮的代码:
import tkinter as tk
import sqlite3
class Page(tk.Frame):
def __init__(self, *args, **kwargs):
tk.Frame.__init__(self, *args, **kwargs)
def show(self):
self.lift()
class Page1(Page):
fName = ""
sName = ""
address1 = ""
address2 = ""
city = ""
postCode = ""
def __init__(self, *args, **kwargs):
tk.Frame.__init__(self, *args, **kwargs)
#Set up labels
spaceLabel = tk.Label(self, text="")
fNameLabel = tk.Label(self, text="First Name: ")
sNameLabel = tk.Label(self, text="Last Name: ")
address1Label = tk.Label(self, text="Address Line 1: ")
cityLabel = tk.Label(self, text="City: ")
postCodeLabel = tk.Label(self, text="Post Code: ")
#Create string variables
self.fName = tk.StringVar()
self.sName = tk.StringVar()
self.address1 = tk.StringVar()
self.address2 = tk.StringVar()
self.city = tk.StringVar()
self.postCode = tk.StringVar()
#Set up text entry boxes
fNameBox = tk.Entry(self, textvariable = self.fName)
sNameBox = tk.Entry(self, textvariable = self.sName)
address1Box = tk.Entry(self, textvariable = self.address1)
address2Box = tk.Entry(self, textvariable = self.address2)
cityBox = tk.Entry(self, textvariable = self.city)
postCodeBox = tk.Entry(self, textvariable = self.postCode)
#Arrange Labels
spaceLabel.grid(row=0, column=0)
fNameLabel.grid(row=1, column=0, padx = 10, pady = 10)
sNameLabel.grid(row=1, column=2, padx = 10, pady = 10)
address1Label.grid(row=2, column=0, padx = 10, pady = 10)
address2Label.grid(row=3, column=0, padx = 10, pady = 10)
cityLabel.grid(row=4, column=0, padx = 10, pady = 10)
postCodeLabel.grid(row=5, column=0, padx = 10, pady = 10)
#Arrange text entry boxes
fNameBox.grid(row=1, column=1, padx = 10, pady = 10)
sNameBox.grid(row=1, column=3, padx = 10, pady = 10)
address1Box.grid(row=2, column=1, padx = 10, pady = 10)
address2Box.grid(row=3, column=1, padx = 10, pady = 10)
cityBox.grid(row=4, column=1, padx = 10, pady = 10)
postCodeBox.grid(row=5, column=1, padx = 10, pady = 10)
#Save Details button
saveCustomerDetails = tk.Button(self, text = "Save Details", command = self.SaveDetails)
saveCustomerDetails.pack()
saveCustomerDetails.grid(row=6,column=2,padx = 20, pady = 20)
#When you click one save button, it should use this method to add the data
# entry field text to the database.
def SaveDetails(self):
conn = sqlite3.connect('lanyard.db')
c = conn.cursor()
c.execute('PRAGMA foreign_keys = ON')
conn.commit()
customerData = [(None, self.fName, self.sName, self.address1, self.address2, self.city, self.postCode)]
for element in customerData:
c.execute("INSERT INTO Customers VALUES (?,?,?,?,?,?,?)", element)
conn.commit()
c.close()
conn.close()
fNameBox.delete(0, END)
sNameBox.delete(0, END)
address1Box.delete(0, END)
address2Box.delete(0, END)
cityBox.delete(0, END)
postCodeBox.delete(0, END)
print ("Saved")
SQLite数据库创建如下:
import sqlite3
conn = sqlite3.connect('lanyard.sqlite')
cursor = conn.cursor()
#Customers
cursor.execute('''DROP TABLE IF EXISTS Archive''')
cursor.execute('''CREATE TABLE IF NOT EXISTS Customers(
Customer_Id INTEGER PRIMARY KEY,
First_Name TEXT(20),
Last_Name TEXT(20),
Address_1 TEXT(20),
Address_2 TEXT(20),
City TEXT(20),
Post_Code TEXT(20))''')
cursor.execute('''PRAGMA foreign_keys = ON''')
cursor.close()
conn.commit()
conn.close()
最佳答案
sqlite 不知道 StringVar
是什么——您必须向其传递正常值。尝试更改您的 customerData
列表,如下所示:
customerData = [(None, self.fName.get(), self.sName.get(),
self.address1.get(), self.address2.get(),
self.city.get(), self.postCode.get())]
关于python - 使用 python/tkinter/sqlite 保存按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16120474/
在 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
我是一名优秀的程序员,十分优秀!