python编写登陆模块

简介: 通过python编写登陆模块,主要是使用openpyxl对excell表格的操作

# auth marcuya
'''
作业:编写登陆模块
1.输入用户名和密码
2.认证成功显示欢迎信息
3.输错3次后锁定用户
设计思路:
1.用户信息保存文件有5个字段:序号,用户名,密码,密码输入错误次数,是否锁定
2.密码输入错误次数大于2,锁定字段为TRUE,用户不能登陆'''

import openpyxl

while True:

   #获取用户输入的用户名和密码
   print()

   _username = input("please input username:")

   _password = input("please input password:")

   # 打开文件
   userInfoFile = openpyxl.load_workbook("homeWork1CountInfo.xlsx")

   userInfoSheet = userInfoFile.active

   #errorcount = userInfoSheet.cell(row=2, column=4)
   #print(errorcount.value)
   #errorcount.value = 3
   #userInfoFile.save("homeWork1CountInfo.xlsx")
   #逐行轮询
   for rows in userInfoSheet.iter_rows():

       no = rows[0]

       username = rows[1]

       password = rows[2]

       errorCount = rows[3]

       lock = rows[4]

       #print("{} {} {} {} {}".format(no.value, username.value, password.value, errorCount.value, lock.value))
       if _username == username.value:

           #账户被锁定
           if lock.value == True:

               print("too many error count to input, the user {user} is locked,please contact administrator!".format(user=username.value))

               break
           #密码正确,此处需要把值统一为字符类型对比
           elif _password == str(password.value):

               print("welcome user {user} login !".format(user = username.value))

               #将输入错误次数置0
               userInfoSheet.cell(row=(no.value + 1), column=4).value = 0
               userInfoFile.save("homeWork1CountInfo.xlsx")

               break
           else:

               #密码错误,密码输入错误次数+1
               errorCount.value = errorCount.value + 1
               userInfoSheet.cell(row=(no.value+1), column=4).value = errorCount.value

               userInfoFile.save("homeWork1CountInfo.xlsx")

               print("invalid username or password")

           #密码输入错误次数大于等于3,锁定账户
           if errorCount.value > 2:

               lock.value = True
               userInfoSheet.cell(row=(no.value+1), column=5).value = True
               userInfoFile.save("homeWork1CountInfo.xlsx")

               break
           else:

               break

相关文章
|
2月前
|
开发者 Python
如何在Python中管理模块和包的依赖关系?
在实际开发中,通常会结合多种方法来管理模块和包的依赖关系,以确保项目的顺利进行和可维护性。同时,要及时更新和解决依赖冲突等问题,以保证代码的稳定性和可靠性
72 4
|
1月前
|
Python
Python Internet 模块
Python Internet 模块。
124 74
|
2月前
|
算法 数据安全/隐私保护 开发者
马特赛特旋转算法:Python的随机模块背后的力量
马特赛特旋转算法是Python `random`模块的核心,由松本真和西村拓士于1997年提出。它基于线性反馈移位寄存器,具有超长周期和高维均匀性,适用于模拟、密码学等领域。Python中通过设置种子值初始化状态数组,经状态更新和输出提取生成随机数,代码简单高效。
130 63
|
2月前
|
数据可视化 Python
如何在Python中解决模块和包的依赖冲突?
解决模块和包的依赖冲突需要综合运用多种方法,并且需要团队成员的共同努力和协作。通过合理的管理和解决冲突,可以提高项目的稳定性和可扩展性
|
2月前
|
测试技术 Python
手动解决Python模块和包依赖冲突的具体步骤是什么?
需要注意的是,手动解决依赖冲突可能需要一定的时间和经验,并且需要谨慎操作,避免引入新的问题。在实际操作中,还可以结合使用其他方法,如虚拟环境等,来更好地管理和解决依赖冲突😉。
|
15天前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
26 3
|
2月前
|
持续交付 Python
如何在Python中自动解决模块和包的依赖冲突?
完全自动解决所有依赖冲突可能并不总是可行,特别是在复杂的项目中。有时候仍然需要人工干预和判断。自动解决的方法主要是提供辅助和便捷,但不能完全替代人工的分析和决策😉。
|
2月前
|
Python
Python的模块和包
总之,模块和包是 Python 编程中非常重要的概念,掌握它们可以帮助我们更好地组织和管理代码,提高开发效率和代码质量
56 5
|
2月前
|
JavaScript 前端开发 Python
python中的OS模块的基本使用
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。博客分享前端技术及全栈开发经验,持续更新中,期待您的关注和支持!🎉🎉🎉
47 0
|
2月前
|
JavaScript 前端开发 Python
python中的platform模块的基本使用
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。博客分享前端技术,助你成长。关注我,持续更新中!🎉🎉🎉
35 0