[英]Error while inserting a value in Python tkinter Entry box
I was making a program that takes values from a user and then appends that values to a db file using sqlite3 database. 我正在制作一个程序,该程序从用户那里获取值,然后使用sqlite3数据库将该值附加到db文件中。 But while inserting the value to entry box a strange error occured.
但是,当将值插入输入框时,发生了奇怪的错误。
import sqlite3,time,datetime
from Tkinter import *
def create_table():
conn = sqlite3.connect("medicaps.db")
c = conn.cursor()
c.execute("CREATE TABLE data(NAME TEXT,ENROLLMENT_NUMBER INT,MARKS INT,GRADE TEXT,UNIXTIME REAL ,DATETIME TEXT)")
class Application(Frame):
def __init__(self,master):
Frame.__init__(self,master)
self.grid()
self.create_widgets()
def create_widgets(self):
Label(self,text = "Welcome to the database entry program.").grid(row = 0,column = 0,columnspan = 2,sticky = W)
Label(self,text = "Name : ").grid(row = 1,column = 0,sticky = W)
Label(self,text = "Enrollment number : ").grid(row = 2,column = 0,sticky = W)
Label(self,text = "Marks : ").grid(row = 3,column = 0,sticky = W)
Label(self,text = "Grade : ").grid(row = 4,column = 0,sticky = W)
self.name = Entry(self)
self.name.grid(row = 1,column = 1)
self.number = Entry(self)
self.number.grid(row = 2,column = 1)
self.marks = Entry(self)
self.marks.grid(row = 3,column = 1)
self.grade = Entry(self)
self.grade.grid(row = 4,column = 1)
self.text = Text(self,width = 35,height = 25,wrap = WORD)
self.text.grid(row = 6,column = 0,columnspan = 2,sticky = W)
Button(self,text = "Submit",command = self.reveal).grid(row = 5,column = 0,sticky = W)
def reveal(self):
conn = sqlite3.connect("medicaps.db")
c = conn.cursor()
unix = time.time()
date = str(datetime.datetime.fromtimestamp(int(time.time())).strftime("%Y-%M-%d %H:%M:%S"))
name = self.name.get()
number = self.number.get()
marks = self.marks.get()
grade = self.grade.get()
self.text.insert(0.0,"yoyo")
try:
number = int(number)
except(ValueError):
error_n = "Invalid Input"
self.number.insert(0.0,error_n)
try:
marks = int(number)
except(ValueError):
error_m = "Invalid Input"
self.marks.insert(0.0,error_m)
c.execute("INSERT INTO data(NAME,ENROLLMENT_NUMBER,MARKS,GRADE,UNIXTIME,DATETIME) VALUES = (?,?,?,?,?,?)",
(name,number,marks,grade,unix,date))
conn.commit()
message = "Value appended successfully"
self.text.delete(0.0,END)
root = Tk()
root.title("Dataentry")
root.geometry("500x750")
frame = Application(root)
root.mainloop()
The following error was raised 引发以下错误
File "C:\Python27\lib\lib-tk\Tkinter.py", line 1536, in __call__
return self.func(*args)
File "C:\Users\sahib navlani\Desktop\New folder\vdsf.py", line 62, in reveal
self.number.insert(0.0,error_n)
File "C:\Python27\lib\lib-tk\Tkinter.py", line 2517, in insert
self.tk.call(self._w, 'insert', index, string)
TclError: bad entry index "0.0"
The error is telling you exactly what the problem is. 该错误告诉您确切的问题是什么。
0.0
is a bad index. 0.0
是一个错误的索引。 self.number
is an Entry
, and indexes are integers starting at zero. self.number
是一个Entry
,索引是从零开始的整数。
You also try to use this same index for a Text
widget, which is also invalid. 您还尝试对
Text
小部件使用相同的索引,这也是无效的。 Text
widget indexes are a string ( not floating point number) of the form <line>.<char> , where <line> is the number number starting at 1
(one) and <char> starts with 0
(zero). Text
窗口小部件索引是格式为<line>。<char>的字符串( 不是浮点数),其中<line>是从1
(一)开始的数字,而<char>从0
(零)开始的数字。 Thus, the very first index of a Text
widget is the string "1.0"
. 因此,
Text
小部件的第一个索引是字符串"1.0"
。
Read the traceback in relation to your code. 阅读与您的代码有关的追溯。 self.number is an Entry().
self.number是一个Entry()。 An entry index is defined in this fine reference , which I recommend that people bookmark.
在这个精细的参考文献中定义了一个条目索引,我建议人们使用书签。 Since Entry widgets contain a single line of text, an index for such is single int.
由于Entry小部件包含一行文本,因此此类的索引是single int。 Try
0
instead of 0.0
. 尝试使用
0
而不是0.0
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.