说明:
Entry(输入框) 组件通常用于获取用户的输入文本。
使用条件:
Entry 组件在GUI界面的设计中主要用于单行文本的键入(实际键入的内容可以比显示的空间更长,此种情况下结束鼠标和位移键能够产看自己输入的隐藏内容),通过几何外观图形属性设计可以改变实际的元素表现
如果你希望接收多行文本的输入,可以使用 Text 组件(后面介绍)。
常见用法:
- 普通输入框
作为输入框最重要的属性是输入内容的获取:
eg:
par1 = tk.StringVar()
par1.set('xxxx')
Entry(window, width=30, foreground='green', textvariable=par1).place(x=180, y=30)
par1.get() # 获取变量参数的键入内容
- 光标移动触发事件
from tkinter import *
import pyodbc
import tkinter as tk
window = tk.Tk()
window.geometry('600x400')
connect = pyodbc.connect(r'DRIVER={SQL Server Native Client 10.0};'
r''r'SERVER=(local);'
r''r'DATABASE=DBtest;UID=sa;PWD=726803')
cursor = connect.cursor()
def data_save(): # .........................数据存储函数
print("the lengh is :", len(str(e1.get())))
if len(str(e1.get())) > 0:
Production_mode = par.get()
Equipment_no = par1.get()
Date = par2.get()
sql1 = "INSERT INTO display_board (Production_mode, Equipment_no, Date ) VALUES ('%s', '%s', '%s')" % (
Production_mode, Equipment_no, Date)
print("Pro_mode_entry_night\n, Pro_equ_no\n, Date\n", Production_mode, Equipment_no, Date)
cursor.execute(sql1)
connect.commit()
print("存储任务完成")
return True
else:
print("等待下一轮存储任务指令")
e1.delete(0, "end")
return False
def test():
if len(e1.get()) > 4:
print("正确!")
return True
else:
print("错误!")
print("the lengh is :", len(e1.get()))
e1.delete(0, "end")
return False
v = tk.StringVar()
par = tk.StringVar()
par1 = tk.StringVar()
par2 = tk.StringVar()
for i in range(0, 3):
if i == 0:
par.set('')
Entry(window, width=30, foreground='green', textvariable=par).place(x=180, y=30)
elif i == 1:
par1.set('')
Entry(window, width=30, foreground='green', textvariable=par1).place(x=180, y=60)
else:
par2.set('')
Entry(window, width=30, foreground='green', textvariable=par2).place(x=180, y=90)
e1 = tk.Entry(window, textvariable=v, validate="focusout", validatecommand=data_save) # 鼠标移走数据存储
e1.pack(padx=180, pady=120)
window.mainloop()
- 与其他事件绑定使用
将 Entry 组件和 Button 组件配合,点击 “获取信息” 按钮时自动清空输入框并将内容输出:
import tkinter as tk
master = tk.Tk()
tk.Label(master, text="作品:").grid(row=0)
tk.Label(master, text="作者:").grid(row=1)
e1 = tk.Entry(master)
e2 = tk.Entry(master)
e1.grid(row=0, column=1, padx=10, pady=5)
e2.grid(row=1, column=1, padx=10, pady=5)
def show():
print("作品:《%s》" % e1.get())
print("作者:%s" % e2.get())
e1.delete(0, "end")
e2.delete(0, "end")
tk.Button(master, text="获取信息", width=10, command=show).grid(row=3, column=0, sticky="w", padx=10, pady=5)
tk.Button(master, text="退出", width=10, command=master.quit).grid(row=3, column=1, sticky="e", padx=10, pady=5)
master.mainloop()
Entry常用选项定义
参考:https://blog.csdn.net/qq_38970783/article/details/88851045
经常用到的一些属性:
- validate
说明:
1. 该选项设置是否启用内容验证
Entry(window, textvariable=v, validate="focusout", validatecommand=data_save)
# 当鼠标移开触发data_save函数
- validatecommand (同“ vcmd ”)
说明:
1. 该选项指定一个验证函数,用于验证输入框内容是否合法
2. 验证函数需要返回 True 或 False 表示验证结果
3. 注意,该选项只有当 validate 的值非 “none” 时才有效 - textvariable
说明:
1. 指定一个与输入框的内容相关联的 Tkinter 变量**(通常是 StringVar)**
2. 当输入框的内容发生改变时,该变量的值也会相应发生改变 - width
说明:
1. 设置输入框的宽度,以字符为单位
2. 默认值是 20
3. 对于变宽字体来说,组件的实际宽度等于字体的平均宽度乘以 width 选项的值
方法
delete(first, last=None)
– 删除参数 first 到 last 范围内(包含 first 和 last)的所有内容
– 如果忽略 last 参数,表示删除 first 参数指定的选项
– 使用 delete(0, END) 实现删除输入框的所有内容
get()
– 获得当前输入框的内容
icursor(index)
– 将光标移动到 index 参数指定的位置
– 这同时也会设置 INSERT 的值
index(index)
– 返回与 index 参数相应的选项的序号(例如 e.index(END))
insert(index, text)
– 将 text 参数的内容插入到 index 参数指定的位置
– 使用 insert(INSERT, text) 将 text 参数指定的字符串插入到光标的位置
– 使用 insert(END, text) 将 text 参数指定的字符串插入到输入框的末尾
scan_dragto(x)
– 见下方 scan_mark(x)
scan_mark(x)
– 使用这种方式来实现输入框内容的滚动
– 需要将鼠标按下事件绑定到 scan_mark(x) 方法(x 是鼠标当前的水平位置),然后再将 事件绑定到 scan_dragto(x) 方法(x 是鼠标当前的水平位置),就可以实现输入框在当前位置和 sacn_mack(x) 指定位置之间的水平滚动
select_adjust(index)
– 与 selection_adjust(index) 相同,见下方解释
select_clear()
– 与 selection_clear() 相同,见下方解释
select_from(index)
– 与 selection_from(index) 相同,见下方解释
select_present()
– 与 selection_present() 相同,见下方解释
select_range(start, end)
– 与 selection_range(start, end) 相同,见下方解释
select_to(index)
– 与 selection_to(index) 相同,见下方解释
selection_adjust(index)
– 该方法是为了确保输入框中选中的范围包含 index 参数所指定的字符
– 如果选中的范围已经包含了该字符,那么什么事情也不会发生
– 如果选中的范围不包含该字符,那么会从光标的位置将选中的范围扩展至该字符
selection_clear()
– 取消选中状态
selection_from(index)
– 开始一个新的选中范围
– 会设置 ANCHOR 的值
selection_present()
– 返回输入框是否有处于选中状态的文本
– 如果有则返回 True,否则返回 False
selection_range(start, end)
– 设置选中范围
– start 参数必须必 end 参数小
– 使用 selection_range(0, END) 选中整个输入框的所有内容
selection_to(index)
– 选中 ANCHOR 到 index 参数的间的所有内容
xview(index)
– 该方法用于确保给定的 index 参数所指定的字符可见
– 如有必要,会滚动输入框的内容
xview_moveto(fraction)
– 根据 fraction 参数给定的比率调整输入框内容的可见范围
– fraction 参数的范围是 0.0 ~ 1.0,0.0 表示输入框的开始位置,1.0 表示输入框的结束位置
xview_scroll(number, what)
– 根据给定的参数水平滚动输入框的可见范围
– number 参数指定滚动的数量,如果是负数则表示反向滚动
– what 参数指定滚动的单位,可以是 UNITS 或 PAGES(UNITS 表示一个字符单元,PAGES 表示一页)
关于验证详解
validatecommand 选项指定一个验证函数,该函数只能返回 True 或 False 表示验证的结果。一般情况下验证函数只需要知道输入框的内容即可,可以通过 Entry 组件的 get() 方法获得该字符串。
import tkinter as tk
master = tk.Tk()
def test():v
if len(v.get()) > 4:
print("键入内容合法")
return True
else:
print("键入内容不合法")
e1.delete(0, "end")
return False
def test1():
print("我被调用了......")
return True
v = tk.StringVar()
tk.Entry(master, textvariable=v, validate="focusout", validatecommand=test, invalidcommand=test1).pack(padx=10, pady=10)
# 将焦点转移到第二个输入框,validatecommand 指定的验证函数被触发并返回 False,接着 invalidcommand 被触发
master.mainloop()