百万年薪python之路 -- 模拟三次账号登录锁定功能
用代码实现三次用户登录及锁定(选做,时间充足建议做一做)
项目分析:
一.首先程序启动,显示下面内容供用户选择:
1.注册
2.登录
a.用户选择登录的时候,首先判断用户名在userinfo.txt表中存在不在,存在就不能进行注册
b.当注册的用户名不存在的时候将用户名和密码写入到userinfo.txt文件中
c.用户选择登录的时候,判断用户输入的账号和密码是否userinfo.txt存储的一致
d.用户名和密码一致就终止循环,并提示用户登录成功!
e.用户名和密码不一致,只有三次登录机会,三次过后提示用户名被锁定,请联系管理员!并终止循环
f.当用户名输出三次,再次运行程序.登录锁定的账号继续提示用户名被锁定,请联系管理员!
import os
count = 0
dic = {}
def locked(login_user,count = 3):
with open("userinfo.txt", "r", encoding="UTF-8") as f4, open("userinfo_bak.txt", "w", encoding="UTF-8") as f5:
for i in f4:
i = i.strip().split(":")
if i[0] == login_user:
i[0] = i[0].replace(i[0], i[0] + "$")
f5.write(f"{i[0]}:{i[1]}\n")
# print(f"你输错了{count}次!")
print(f"检测到用户名{login_user}已经输错了{count}次,已锁定!请联系管理员!")
os.remove("userinfo.txt")
os.rename("userinfo_bak.txt", "userinfo.txt")
def user_login_count(login_user):
with open("userinfo.txt", "r", encoding="UTF-8") as f:
for i in f:
i = i.strip().split(":")
if i[0][-1] == "$" and i[0][0:-1] == login_user:
dic[login_user] = 3
if dic.get(login_user,0) != 3:
dic[login_user] = dic.get(login_user,0) + 1
# print(dic[login_user])
return dic[login_user]
def register():
user = input("请输入注册用户名(退出程序请按q/Q):")
if user.lower() == "q":
return "q"
while 1:
pwd = input("请输入注册密码:")
if not pwd.strip():
print("注册密码不能为空!请重新输入!")
else:
break
with open("userinfo.txt", "r", encoding="UTF-8") as f:
flag = True
for i in f:
i = i.split(":")
if user == i[0]:
print("用户名已存在!")
flag = False
if flag == True:
with open("userinfo.txt", "a", encoding="UTF-8") as f1:
f1.write(user + ":" + pwd + "\n")
print("注册成功!")
def login():
flag = False
while 1:
login_user = input("请输入登录用户名(退出程序请按q/Q):")
if login_user.lower() == "q":
return "q"
login_pwd = input("请输入登录密码:")
with open("userinfo.txt","r",encoding="UTF-8") as f:
for i in f:
i = i.strip().split(":")
if i[0][-1] == "$" and i[0][0:-1] == login_user:
print(f"用户名{login_user}已被锁!")
break
elif i[0] == login_user and i[1] == login_pwd:
flag = True
break
if flag != True:
ret = user_login_count(login_user)
if ret == 3:
locked(login_user)
else:
print(f"登陆失败,你已经输错{ret}次了!")
else:
print("登陆成功!")
dic[login_user] = 0
break
while 1:
inp = input("请输入序号(1/注册,2/登录,q或Q/退出程序):")
if inp == "1" or inp == "2" or inp.lower() == "q":
if inp == "1":
if register() == "q":
break
elif inp == "2":
if login() == "q":
break
elif inp.lower() == "q":
print("已退出程序!")
break
else:
print("请重新输入!")
百万年薪python之路 -- 模拟三次账号登录锁定功能的更多相关文章
- 百万年薪python之路 -- 模块三
logging 日志模块 loggin模块参数 灵活配置日志级别,日志格式,输出位置: import logging logging.basicConfig(level=logging.DEBUG, ...
- 百万年薪python之路 -- 软件的开发规范
一. 软件的开发规范 什么是开发规范?为什么要有开发规范呢? 你现在包括之前写的一些程序,所谓的'项目',都是在一个py文件下完成的,代码量撑死也就几百行,你认为没问题,挺好.但是真正的后端开发的项目 ...
- 百万年薪python之路 -- 并发编程之 多进程二
1. 僵尸进程和孤儿进程 基于unix的环境(linux,macOS) 主进程需要等待子进程结束之后,主进程才结束 主进程时刻检测子进程的运行状态,当子进程结束之后,一段时间之内,将子进程进行回收. ...
- 百万年薪python之路 -- 并发编程之 多线程 三
1. 阻塞,非阻塞,同步,异步 进程运行的三个状态: 运行,就绪,阻塞. 从执行的角度: 阻塞: 进程运行时,遇到IO了,进程挂起,CPU被切走. 非阻塞: 进程没有遇到IO 当进程遇到IO, ...
- 百万年薪python之路 -- 数据库初始
一. 数据库初始 1. 为什么要有数据库? 先来一个场景: 假设现在你已经是某大型互联网公司的高级程序员,让你写一个火车票购票系统,来hold住十一期间全国的购票需求,你怎么写? 由于在同一时 ...
- 百万年薪python之路 -- 并发编程之 协程
协程 一. 协程的引入 本节的主题是基于单线程来实现并发,即只用一个主线程(很明显可利用的cpu只有一个)情况下实现并发,为此我们需要先回顾下并发的本质:切换+保存状态 cpu正在运行一个任务,会在两 ...
- 百万年薪python之路 -- MySQL数据库之 Navicat工具和pymysql模块
一. IDE工具介绍(Navicat) 生产环境还是推荐使用mysql命令行,但为了方便我们测试,可以使用IDE工具,我们使用Navicat工具,这个工具本质上就是一个socket客户端,可视化的连接 ...
- 百万年薪python之路 -- 面向对象之继承
面向对象之继承 1.什么是面向对象的继承 继承(英语:inheritance)是面向对象软件技术当中的一个概念. 通俗易懂的理解是:子承父业,合法继承家产 专业的理解是:子类可以完全使用父类的方法和属 ...
- 百万年薪python之路 -- JS基础介绍及数据类型
JS代码的引入 方式1: <script> alert('兽人永不为奴!') </script> 方式2:外部文件引入 src属性值为js文件路径 <script src ...
随机推荐
- Linux之VMWare下Centos7的三种网络配置过程
Linux之VMWare下Centos7的三种网络配置过程 环境: 虚拟软件:VMWare 14.0 客户机:windows 10 虚拟机:centos 7 VMware三种网络连接方式 Bridge ...
- python语言程序设计基础 习题 天天向上的力量(math.pow)
实例1: 一年365天,,以第一天的能力值为基数1.0,当好好学习时能力值相比前一天提高1%,没有学习时能力值相比前天要降低1%,每天努力和每天放任,一年下来的能力值相差多少? 解析: 如果每天都好好 ...
- Spark 学习笔记之 map/flatMap/filter/mapPartitions/mapPartitionsWithIndex/sample
map/flatMap/filter/mapPartitions/mapPartitionsWithIndex/sample:
- Spark 学习笔记之 Streaming和Kafka Direct
Streaming和Kafka Direct: Spark version: 2.2.0 Scala version: 2.11 Kafka version: 0.11.0.0 Note: 最新版本感 ...
- Kafka 学习笔记之 High Level Consumer相关参数
High Level Consumer相关参数 自动管理offset auto.commit.enable = true auto.commit.interval.ms = 60*1000 手动管理o ...
- MongoDB 学习笔记之 replica set搭建
Replica set搭建: 修改mongodb.conf文件,指明replSet 登入客户端,指定副本集成员,进行初始化, 如果priority需要调整,使用reconfig()方法.Seconda ...
- laravel 5.5 运行在 php7.0 报错 Symfony\Component\Translation\Translator.php FatalThrowableErrorParse error: syntax error, unexpected '?', expecting variable (T_VARIABLE)
问题描述 报错原因是 php-cli 版本是 7.1.x,运行 composer create-project ... 命令时安装的依赖包会自动适配到当前 php 版本 7.1.x.如果 php-fp ...
- centos7 scrapy安装
1.anaconda3安装 wget https://repo.anaconda.com/archive/Anaconda3-2019.03-Linux-x86_64.sh 安装报错,可能是源的问题 ...
- beego之操作model
beego之操作model 1.环境配置 1>.下载安装orm go get github.com/astaxie/beego/orm 默认安装路径在gopath路径下,可使用go env查看路 ...
- tensorflow中添加L2正则化损失
方法有几种,总结一下方便后面使用. 1. tensorflow自动维护一个tf.GraphKeys.WEIGHTS集合,手动在集合里面添加(tf.add_to_collection())想要进行正则化 ...