Python中tkinter的用户登录管理的实现

这篇文章主要介绍了Python中tkinter的用户登录管理的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

内容

编写一个用户登录管理程序,设计窗体的布局,制定密码规则和验证码规则。要求使用 Python 标准库 tkinter 编写基于GUI 的用户登录窗体。通过该窗体,用户输入用户名、密码和验证码等信息,确认登录后需要判断用户信息是否合法,并弹出对应的反馈信息。通过判断用户是否在用户信息中,以及输入密码是否与用户信息文件中用户名所对应的密码是否相同,来判断用户是否合法。此外,新用户还可以进行注册,注册需要输入用户名、密码、手机号和身份证号等信息。注册时密码需要遵循一定规则(长度不小于8且含有数字、字母和特殊字符),注册后将用户信息存储到文件中,更新用户信息文件。步骤

流程图

代码

 from tkinter import * from tkinter import messagebox import os import xlrd from xlutils.copy import copy login=Tk() login.title('登录界面') # 设计窗口大小 login.geometry('210x200') # 设计GUI用户登录窗体 Label(login,text="用户登录").grid(row=0,column=0,columnspan=2) Label(login,text="用户名").grid(row=1,column=0) name=Entry(login) name.grid(row=1,column=1) Label(login,text="密码:").grid(row=2,column=0) passWord=Entry(login,show='●') passWord.grid(row=2,column=1) Label(login,text="验证码:").grid(row=3,column=0,sticky=E) verifyCode=Entry(login) verifyCode.grid(row=3,column=1) # 判断用户是否在用户信息.xls文件中 def isInExcel(data): filename = "用户信息.xls" excel = xlrd.open_workbook(filename, encoding_override="utf-8") sheet = excel.sheets()[0] sheet_row_mount = sheet.nrows # 行数 sheet_col_mount = sheet.ncols # 列数 sheet_name = [] # 所有用户名信息 for x in range(1, sheet_row_mount): y = 0 sheet_name.append(sheet.cell_value(x, y)) for x in sheet_name: # 找到用户名 if (data == x): # 已有用户 return 1 break; # 未注册用户 return -1 # 用户存在时,判断密码是否正确 def isPasswordDirect(data,passWord): filename = "用户信息.xls" excel = xlrd.open_workbook(filename, encoding_override="utf-8") sheet = excel.sheets()[0] sheet_row_mount = sheet.nrows # 行数 sheet_col_mount = sheet.ncols # 列数 sheet_name = [] # 所有用户名信息 for x in range(1, sheet_row_mount): y = 0 sheet_name.append(sheet.cell_value(x, y)) sheet_passWord=[] # 所有密码信息 for x in range(1, sheet_row_mount): y = 1 sheet_passWord.append(sheet.cell_value(x, y)) for i in range(len(sheet_name)): if(data==sheet_name[i]): # 记录用户名在数组中的位置 record=i break for i in range(len(sheet_passWord)): if(passWord==sheet_passWord[i]): # 判断用户名位置与密码位置是否相同 # 以及密码是否与用户信息中的密码一致 if(i==record): # 密码正确 return 1 break # 密码错误 return -1 def successful(): # 判断用户名不存在 if (isInExcel(name.get())==-1): messagebox.showerror(title='wrong', message='用户不存在,请注册') # 密码不正确 elif (isPasswordDirect(name.get(),passWord.get())==-1): messagebox.showerror(title='wrong', message='密码不正确') # 验证码位数不正确 elif len(verifyCode.get())!=4: messagebox.showerror(title='wrong',message='验证码应为4位') else: messagebox.showinfo(title='successful',message='登录成功') Button(login, text='发送验证码').grid(row=4, column=0, columnspan=3) Button(login,text='登录',command=successful).grid(row=5,column=0,columnspan=3) # 设计用户注册GUI界面 def registereds(): registered=Tk() registered.title('registered') registered.geometry('230x185') Label(registered, text='用户注册').grid(row=0, column=0, columnspan=2) Label(registered, text='用户名:').grid(row=1, column=0, sticky=E) names = Entry(registered) names.grid(row=1, column=1) Label(registered, text='密码:').grid(row=2, column=0, sticky=E) passwds = Entry(registered, show='●') passwds.grid(row=2, column=1) Label(registered, text='确认密码:').grid(row=3, column=0) repasswd = Entry(registered, show='●') repasswd.grid(row=3, column=1) Label(registered, text='手机号:').grid(row=4, column=0, sticky=E) phonenum = Entry(registered) phonenum.grid(row=4, column=1) Label(registered, text='身份证号:').grid(row=5, column=0) man = Entry(registered) man.grid(row=5, column=1) # 判断是否含有特殊符号 def teshufuhao(input_psd): string = "~!@#$%^&*()_+-*/<>,.[]\/" for i in string: if i in input_psd: return True return False def registeredes(): # 密码长度小于8 if len(passwds.get()) <8: messagebox.showerror(title='wrong' , message='注册失败,密码不应少于8位' ) # 密码不同时含有数字、字母和特殊符号 elif not (any([x.isdigit() for x in passwds.get()]) and any([x.isalpha() teshufuhao( passwds.get())): 两次密码输入不一样 passwds.get() !=repasswd.get(): 手机号不正确 (phonenum.get().isdigit() len(phonenum.get())== 11): 身份证号不正确 len(man.get()) 18: else: messagebox.showinfo(title='successful' 将新用户信息存入用户信息文件 excel=xlrd.open_workbook('用户信息.xls') sheet=excel.sheets()[0] nrow=sheet.nrows 文件行数 wb=copy(excel) w_sheet=wb.get_sheet(0) 从数据下一行开始写入新用户信息 w_sheet.write(nrow, 0, names.get()) 1, repasswd.get()) 2, phonenum.get()) 3, man.get()) wb.save('用户信息.xls') button(registered, text='注册' command=registeredes).grid(row=6, column=0, columnspan=3) button(login, login.mainloop()< pre>

结果

(1)密码正确(对照用户信息文件输入密码),结果显示登录成功


(2)密码不正确,结果显示密码不正确

(3)密码正确,验证码位数不对

(4)用户名不存在


5. 注册新用户

(1)新用户写入用户信息文件


(2)再次登录,用户登录成功

到此这篇关于Python中tkinter的用户登录管理的实现的文章就介绍到这了,更多相关tkinter用户登录管理内容请搜索html中文网以前的文章或继续浏览下面的相关文章希望大家以后多多支持html中文网!

以上就是Python中tkinter的用户登录管理的实现的详细内容,更多请关注0133技术站其它相关文章!

赞(0) 打赏
未经允许不得转载:0133技术站首页 » python