2013-04-20 5 views
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() 

답변

1

SQLite는이 StringVar이 무엇인지 모르고있다가 - 당신은 통과해야 그것은 정상적인 값입니다. 다음과 같이 customerData 목록을 변경해보세요.

customerData = [(None, self.fName.get(), self.sName.get(), 
       self.address1.get(), self.address2.get(), 
       self.city.get(), self.postCode.get())] 
+0

완벽합니다. 감사. 그러나 텍스트 필드 상자를 비워야하는 saveDetails 메서드의 코드 줄은 fNameBox가 정의되어 있지 않다고해서 작동하지 않습니다./ – user2302088

+0

@ user2302088 이것은 완전히 다른 질문입니다. (그리고 파이썬은 옳다 : 변수는'SaveDetails' 함수에 정의되어 있지 않다.) –