用python中的tkinter生成一个用户登录注册界面,要求可选择的用户类型有顾客、商家与外卖员三种,要求结合数据库mysql进行编写,用户的账号密码都存储在数据库中

时间: 2024-02-21 07:57:36 浏览: 22
好的,下面是一个基于Python Tkinter 和 MySQL 数据库实现的用户登录注册界面示例代码: ```python import tkinter as tk import mysql.connector # 连接MySQL数据库 mydb = mysql.connector.connect( host="localhost", user="root", password="password", database="mydatabase" ) # 创建一个Tkinter窗口对象 root = tk.Tk() root.title("用户登录注册界面") # 定义登录函数 def login(): username = username_entry.get() password = password_entry.get() user_type = user_type_var.get() cursor = mydb.cursor() sql = "SELECT * FROM user WHERE username = %s AND password = %s AND user_type = %s" val = (username, password, user_type) cursor.execute(sql, val) result = cursor.fetchone() if result: result_label.config(text="登录成功") else: result_label.config(text="登录失败") # 定义注册函数 def register(): username = username_entry.get() password = password_entry.get() user_type = user_type_var.get() cursor = mydb.cursor() sql = "INSERT INTO user (username, password, user_type) VALUES (%s, %s, %s)" val = (username, password, user_type) cursor.execute(sql, val) mydb.commit() result_label.config(text="注册成功") # 创建用户名输入框和标签 username_label = tk.Label(root, text="用户名:") username_label.grid(row=0, column=0) username_entry = tk.Entry(root) username_entry.grid(row=0, column=1) # 创建密码输入框和标签 password_label = tk.Label(root, text="密码:") password_label.grid(row=1, column=0) password_entry = tk.Entry(root, show="*") password_entry.grid(row=1, column=1) # 创建用户类型选择框和标签 user_type_var = tk.StringVar() user_type_label = tk.Label(root, text="用户类型:") user_type_label.grid(row=2, column=0) user_type_entry = tk.OptionMenu(root, user_type_var, "顾客", "商家", "外卖员") user_type_entry.grid(row=2, column=1) # 创建登录和注册按钮 login_button = tk.Button(root, text="登录", command=login) login_button.grid(row=3, column=0) register_button = tk.Button(root, text="注册", command=register) register_button.grid(row=3, column=1) # 创建登录结果标签 result_label = tk.Label(root, text="") result_label.grid(row=4, columnspan=2) # 运行Tkinter窗口 root.mainloop() # 关闭MySQL数据库连接 mydb.close() ``` 在代码中,我们首先通过`mysql.connector`模块连接到MySQL数据库。然后,我们创建了一个Tkinter窗口,包含用户名输入框、密码输入框、用户类型选择框、登录按钮、注册按钮和登录结果标签。当用户点击登录或注册按钮时,程序会根据用户输入的用户名、密码和用户类型查询或插入数据库中的用户信息,然后根据查询结果或插入结果更新登录结果标签的文本。最后,我们在程序结束时关闭MySQL数据库连接。 请注意,这只是一个简单的示例代码,实际的用户登录注册系统需要更加复杂和安全。例如,需要进行密码加密、用户名和密码的验证、防止SQL注入攻击等。

相关推荐

最新推荐

recommend-type

基于python的Tkinter编写登陆注册界面

主要为大家详细介绍了基于python的Tkinter编写登陆注册界面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

Python使用tkinter库实现文本显示用户输入功能示例

主要介绍了Python使用tkinter库实现文本显示用户输入功能,结合实例形式分析了tkinter库获取用户输入及控件显示相关操作技巧,需要的朋友可以参考下
recommend-type

在python tkinter界面中添加按钮的实例

今天小编就为大家分享一篇在python tkinter界面中添加按钮的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

Python3.7+tkinter实现查询界面功能

主要介绍了Python3.7+tkinter实现查询界面功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

解决python tkinter界面卡死的问题

今天小编就为大家分享一篇解决python tkinter界面卡死的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。