python 之GUI设计:Entry组件

说明:
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()

将焦点转移到第二个输入框,validatecommand 指定的验证函数被触发并返回 False,接着 invalidcommand 被触发

猜你喜欢

转载自blog.csdn.net/weixin_44322778/article/details/105757170
今日推荐