1
고객 정보를 입력하기위한 이름과 주소를 입력 할 수있는 텍스트 상자가있는 tkinter 프레임 페이지가 있습니다. 같은 페이지에는 텍스트 상자의 세부 정보를 .sqlite 데이터베이스에 저장하는 다른 메서드에 연결된 저장 단추가 있습니다. 그러나 버튼을 클릭하면 "sqlite3.InterfaceError : 매개 변수 1을 바인딩하는 중 오류가 발생했습니다 - 아마도 지원되지 않는 유형입니다." 아주 자명 한 오류가 있지만 올바른 입력으로 변경할 생각이 없습니다. 제발, 어떤 도움이 될 것입니다, 감사합니다! TK에 간 프레임 및 페이지 레이아웃 +에 대한파이썬/tkinter/sqlite로 저장 버튼
코드 버튼 저장 다음과 같이
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()
완벽합니다. 감사. 그러나 텍스트 필드 상자를 비워야하는 saveDetails 메서드의 코드 줄은 fNameBox가 정의되어 있지 않다고해서 작동하지 않습니다./ – user2302088
@ user2302088 이것은 완전히 다른 질문입니다. (그리고 파이썬은 옳다 : 변수는'SaveDetails' 함수에 정의되어 있지 않다.) –