Python实例题:Python百行制作登陆系统

目录

Python实例题

题目

[python-login-systemPython 百行登录系统脚本](#python-login-systemPython 百行登录系统脚本)

代码解释

用户数据库:

注册功能:

登录功能:

主程序:

运行思路

注意事项

Python实例题

题目

Python百行制作登陆系统

python-login-systemPython 百行登录系统脚本

python 复制代码
# 初始化用户数据库,使用字典存储用户名和密码
user_database = {}


def register():
    """
    用户注册功能
    """
    while True:
        username = input("请输入要注册的用户名: ")
        if username in user_database:
            print("该用户名已被注册,请选择其他用户名。")
        else:
            password = input("请输入密码: ")
            user_database[username] = password
            print("注册成功!")
            break


def login():
    """
    用户登录功能
    """
    username = input("请输入用户名: ")
    password = input("请输入密码: ")
    if username in user_database and user_database[username] == password:
        print("登录成功!欢迎,", username)
    else:
        print("用户名或密码错误,请重试。")


def main():
    """
    主程序,提供操作菜单
    """
    while True:
        print("\n--- 登录系统 ---")
        print("1. 注册")
        print("2. 登录")
        print("3. 退出")
        choice = input("请输入你的选择 (1/2/3): ")
        if choice == '1':
            register()
        elif choice == '2':
            login()
        elif choice == '3':
            print("感谢使用,再见!")
            break
        else:
            print("无效的选择,请重新输入。")


if __name__ == "__main__":
    main()
    

代码解释

用户数据库

  • 使用一个字典 user_database 来存储用户名和对应的密码。

注册功能

  • register 函数会提示用户输入用户名和密码。
  • 检查用户名是否已存在于数据库中,如果存在则提示用户重新输入,否则将用户名和密码添加到数据库中。

登录功能

  • login 函数会提示用户输入用户名和密码。
  • 检查输入的用户名和密码是否与数据库中的匹配,如果匹配则登录成功,否则提示错误信息。

主程序

  • main 函数提供一个操作菜单,让用户可以选择注册、登录或退出。
  • 根据用户的选择调用相应的函数。

运行思路

  • 将上述代码保存为 login_system.py 文件。
  • 在终端中运行 python login_system.py
  • 根据菜单提示输入相应的数字进行注册、登录或退出操作。

注意事项

  • 此示例只是一个简单的登录系统,实际应用中需要考虑更多的安全性问题,如密码加密、防止暴力破解等。
  • 用户数据仅在程序运行期间有效,程序关闭后数据会丢失。如果需要持久化存储用户数据,可以考虑使用文件或数据库。
相关推荐
heimeiyingwang19 小时前
【架构实战】SQL调优实战:从执行计划到索引优化
数据库·sql·架构
恼书:-(空寄20 小时前
分库分表风险应对手册(生产实战版)
数据库·分库分表
XDHCOM20 小时前
ORA-06521: PL/SQL映射函数错误,权威解析Oracle报错故障修复与远程处理方案
数据库·sql·oracle
wgzrmlrm7420 小时前
mysql如何配置全文索引停用词_mysql ft_stopword_file设置
jvm·数据库·python
城数派21 小时前
2025年南京市全类别POI(55W+数据)
数据库·arcgis·信息可视化·数据分析·excel
疯狂成瘾者21 小时前
后端系统、服务稳定性里核心的指标有哪些
数据库
SPC的存折21 小时前
openEuler 24.03 MariaDB Galera 集群部署指南(cz)
linux·运维·服务器·数据库·mysql
仲芒21 小时前
[24年单独笔记] MySQL 常用的 DML 命令
数据库·笔记·mysql
SPC的存折1 天前
MySQL 8.0 分库分表
linux·运维·服务器·数据库·mysql
蓦然乍醒1 天前
使用 DBeaver 还原 PostgreSQL 备份文件 (.bak) 技术文档
数据库·postgresql