2.Python GUI之登录
时间:2022-07-25
本文章向大家介绍2.Python GUI之登录,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
#登录
from tkinter import Tk,messagebox,Toplevel
#使用相关的组件
import tkinter as tk
#1.窗体
my_window=Tk()
my_window.title("登录")
#设置窗口大小并居中显示
#屏幕的宽度、高度
screen_width,scree_height=my_window.maxsize()
#窗体的宽度、高度
width=250
height=200
#设置窗体在屏幕中央显示
align_str="%dx%d+%d+%d" % (width,height,(screen_width-width)/2,(scree_height-height)/2)
my_window.geometry(align_str)
#设置宽高不可缩放
my_window.resizable(width=False, height=False)
#添加标签
user_name_label=tk.Label(my_window,text='账号',font=("FangSong",14))
user_name_label.place(x=30,y=30)
user_pwd_label=tk.Label(my_window,text="密码",font=("FangSong",14))
user_pwd_label.place(x=30,y=80)
#输入框
#账号输入
user_name_text=tk.StringVar()
user_name_text.set("输入账号")
user_name_entry=tk.Entry(my_window,textvariable=user_name_text,font=("FangSong",14),width=15)
user_name_entry.place(x=80,y=30)
#密码输入
user_pwd_text=tk.StringVar()
user_pwd_text.set("输入密码")
user_pwd_entry=tk.Entry(my_window,textvariable=user_pwd_text,font=("FangSong",14),width=15)
user_pwd_entry.place(x=80,y=80)
#数据读取
def read_data():
with open("data.txt","r") as f:
rows=f.readlines()
user_info_dict={}
#字典数据封装
for row in rows:
dict_list=row.strip().split(":")
user_info_dict[dict_list[0]]=dict_list[1]
f.close()
return user_info_dict
#登录按钮事件处理回调
def user_login():
# 获取用户输入账号和密码
name=user_name_text.get()
pwd=user_pwd_text.get()
user_dict=read_data()
if name!="" and pwd!="":
if name in user_dict.keys():
if pwd==user_dict[name]:
# print("ok")
messagebox.showinfo(title="成功",message="欢迎"+name)
else:
# print("密码不正确")
messagebox.showerror(title="错误",message="密码不正确")
else:
# print("用户不存在")
messagebox.showerror(title="错误",message="用户不存在")
else:
# print("账号、密码不能为空")
messagebox.showerror(title="错误",message="用户名、密码不能为空")
#弹出注册窗体
def pop_win():
top=Toplevel()
top.title("注册")
top.geometry("250x200")
#账号、密码、确认密码、注册按钮
#gird网格布局方式
tk.Label(top,text="账号",width=10).grid(row=1,column=0)
user_name=tk.StringVar()
tk.Entry(top,textvarilable=user_name,width=15).grid(row=1,column=1)
tk.Label(top,text="密码",width=10).grid(row=2,column=0)
user_pwd=tk.StringVar()
tk.Entry(top,textvarilable=user_pwd,width=15).grid(row=2,column=1)
tk.Label(top,text="确认密码",width=10).grid(row=3,column=0)
user_confirm_pwd=tk.StringVar()
tk.Entry(top,textvarilable=user_confirm_pwd,width=15).grid(row=3,column=1)
#注册按钮的回调函数
def user_register():
#获取输入框的值
name=user_name.get()
pwd=user_pwd.get()
confirm_pwd=user_confirm_pwd.get()
if pwd==confirm_pwd:
with open("data.txt","a") as f:
f.writelines(name+":"+pwd+"n")
f.flush()
f.close()
messagebox.showinfo(title="成功",message="注册成功!")
#销毁窗体
top.destroy()
else:
messagebox.showerror(title="错误",message="两次密码不一致")
tk.Button(top,text="注册",width=10,command=user_register).grid(row=4,columnspan=2,pady=15)
#按钮
#登录按钮,事件处理
user_login_button=tk.Button(my_window,text="登录",font=("FangSong",14),comman=user_login)
user_login_button.place(x=30,y=130)
#注册按钮,事件处理
user_login_button=tk.Button(my_window,text="注册",font=("FangSong",14),comman=pop_win)
user_login_button.place(x=180,y=130)
my_window.mainloop()
# print(read_data())
- java:快速文件分割及合并
- 暴涨210倍的一个数字货币正悄无声息崛起
- QT Creator 快速入门教程 读书笔记(一)
- .NET程序优化(GCServer )
- redis 学习笔记(4)-HA高可用方案Sentinel配置
- oracle: job使用
- velocity模板引擎学习(2)-velocity tools 2.0
- java:如何用代码控制H2 Database启动
- 游戏开发完整学习路线(各个版本都有)
- spring mvc4:异常处理
- TCP/IP, WebSocket 和 MQTT
- struts2: 玩转 rest-plugin
- 设置系统环境变量立即生效的VBS脚本
- velocity模板引擎学习(1)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法