题目:Python实现三次登陆

不要急于马上把三次登陆写出来,一定要将复杂的程序简单化,必须一步一步地去扩展,这样才保证不会出错。

步骤一:实现简单的一次登陆

# 事先定义
user = 'dark_knight'
pwd = 'dk123' username = input('Please enter username:')
password = input('Please enter password:') # 判断
if username == user and password == pwd:
print('Login successfully!')
else:
print('Login failed!')

步骤二:实现简单的三次登陆

# 事先定义
user = 'dark_knight'
pwd = 'dk123'
count = 1 # 定义次数 while True:
if count == 4: # 大于3次则退出循环
print('Too many times!')
break
username = input('Please enter username:')
password = input('Please enter password:') # 判断
if username == user and password == pwd:
print('Login successfully!')
break
else:
print('Login failed!') count += 1 # 每次循环都次数都进行加1操作

  

步骤三:解决三次登陆中的BUG

1、去除字符串两边的空格

2、当用户输入None时则提示用户反复输入。

3、当用户输入的信息不匹配时则告诉用户还有几次机会。

# 事先定义
user = 'dark_knight'
pwd = 'dk123'
count = 1 # 定义次数 while True:
if count == 4: # 大于3次则退出循环
print('Too many times!')
break
username = input('Please enter username:').strip() # 去除字符串两边的空格
password = input('Please enter password:').strip() # 去除字符串两边的空格 # 当用户输入有值时
if username and password:
# 判断
if username == user and password == pwd:
print('Login successfully!')
break
else:
print('Login failed!')
print('You have %s chance.'%(3 - count)) # 当用户输入None时
else:
print('You enter blank, please re-enter!')
continue # 当用户输入None时,跳出本次循环。 count += 1 # 每次循环都次数都进行加1操作

步骤四:扩展三次登陆

要求:将登陆三次失败后的用户进行锁定。

思路:1、先手动创建一个黑名单文件。

   2、再创建一个空列表,将每次输入错误的用户名添加至列表中。

   3、当加入列表中的用户名出现3次相同的用户名时,把这个用户名添加至黑名单进行锁定。

user = 'knight'
pwd = 'dk123'
count = 1
times = [] # 用于统计密码输错时的用户名的个数 with open('blacklist.txt', 'r', encoding='utf-8') as f_black:
black_line = f_black.readlines() # 将黑名单内容以列表的形式读出来
# print(black_line) while True: # 当登陆次数超过3次时提示登陆次数过多,退出程序
if count == 4:
print('Too many times!')
break username = input('Please enter your username:').strip()
password = input('Please enter your password:').strip() # 判断用户名是否为空
if not username:
print('The username you entered is blank, please re-enter')
continue # 判断密码是否为空
elif not password:
print('The password you entered is blank, please re-enter')
continue # 判断用户名再加上"\n"是否在黑名单的列表里,如果在则提示用户已锁定再退出程序
if username + '\n' in black_line:
print('Sorry, your account has been locked!')
break # 判断用户名和密码是否匹配
if username == user and password == pwd:
print('Login successfully!')
break
else:
print('The username or password you entered is incorrect,Please try again!')
print('You still have %s chances' % (3 - count)) # 如果不匹配则提示用户名或密码错误并告之用户还有几次机会 times.append(username) # 将错误的用户名加入至事先定义的times列表中,
if times.count(username) == 3: # 然后计算加入的用户名的个数是否等于三个,如果是则写入至黑名单文件中。
with open('blacklist.txt', 'a', encoding='utf-8')as f:
f.write(username+'\n')
count += 1

  

Python三次登陆的更多相关文章

  1. python小练习:用户三次登陆, 购物车

    2018.12.1 周末练习: 1.用户三次登陆 from random import randint i = 1 while i < 4: num = 0 verify_code = '' w ...

  2. 【小白学爬虫连载(10)】–如何用Python实现模拟登陆网站

    Python如何实现模拟登陆爬取Python实现模拟登陆的方式简单来说有三种:一.采用post请求提交表单的方式实现.二.利用浏览器登陆网站记录登陆成功后的cookies,采用get的请求方式,传入c ...

  3. python实现用户登陆(sqlite数据库存储用户信息)

    python实现用户登陆(sqlite数据库存储用户信息) 目录 创建数据库 数据库管理 简单登陆 有些地方还未完善. 创建数据库 import sqlite3 #建一个数据库 def create_ ...

  4. python通过SSH登陆linux并操作

    使用python通过SSH登陆linux并操作 用的昨天刚接触到的库,在windows下通过paramiko来登录linux系统并执行了几个命令,基本算是初试成功,后面会接着学习的. 代码: > ...

  5. Python实现模拟登陆

    大家经常会用Python进行数据挖掘的说,但是有些网站是需要登陆才能看到内容的,那怎么用Python实现模拟登陆呢?其实网路上关于这方面的描述很多,不过前些日子遇到了一个需要cookie才能登陆的网站 ...

  6. asp:第三平台登陆

    第三平台登陆接口申请网址: http://open.51094.com/ 文档: 第三方合作登录平台使用说明 为方便更多的开发朋友,本人特将当前市面上所有支持第三方联合登录的接口集为一体,以前需要多次 ...

  7. python使用post登陆电子科大信息门户并保存登陆后页面

    python使用post登陆电子科大信息门户并保存登陆后页面 作者:vpoet mail:vpoet_sir@163.com #coding=utf-8 import HTMLParser impor ...

  8. 【转】python 三种遍历list的方法

    [转]python 三种遍历list的方法 #!/usr/bin/env python # -*- coding: utf-8 -*- if __name__ == '__main__': list ...

  9. python爬虫模拟登陆

    python爬虫模拟登陆 学习了:https://www.cnblogs.com/chenxiaohan/p/7654667.html  用的这个 学习了:https://www.cnblogs.co ...

随机推荐

  1. tp系统常量

    ThinkPHP的公共入口文件里定义了系统常量 RUNTIME_PATH----系统运行时目录 LIB_PATH-----------系统核心类库目录 CORE_PATH--------Think类库 ...

  2. oracle关闭

    Alert log 要每天查看 abort 关闭冷备会无法使用

  3. BZOJ1013 + BZOJ1923 + POJ1830 (高斯消元)

    三个题放在一起写了 主要是搞搞模板 在这里简述一下怎么写高斯消元 就和代数里学的加减消元学的一样 把矩阵化为上三角形形式 然后进行回代 同时枚举当前要消元的未知数和当前化简到哪一行了 然后从这一行往后 ...

  4. git学习(2)----入门

    一.git.github和gitlab的区别 Git诞生于2005年,大神Linus的作品,Github诞生于2008年,没有Git就没有GitHub,Github已成为全球最大的代(tong)码(x ...

  5. 第一章 React新的前端思维方式

    ---恢复内容开始--- 第一章 React新的前端思维方式 1.1 初始化一个React项目 1.安装create-react-app npm install --global create-rea ...

  6. java学习日志---File实例:实现复制整个文件夹、解决listFiles()为null问题

    需求:将H盘下的所有文件复制到H:/All 文件夹中 思路:使用递归遍历整个目标目录 传入目标路径 判断是否是文件夹 是:调用listFiles()方法,得到File数组,重点内容接着执行1 否:复制 ...

  7. 关押罪犯 - 并查集&优先队列

    题目地址:http://www.51cpc.com/web/problem.php?id=4261 Summarize: 此题最巧妙的是“敌人的敌人就是朋友!”,故需先将敌对关系放入优先队列,按怨恨值 ...

  8. 「 HDU P3555 」 Bomb

    # 题目大意 给出 $\text{T}$ 个数,求 $[1,n]$ 中含 ‘49’ 的数的个数. # 解题思路 求出不含 '49' 的数的个数,用总数减去就是答案. 数位 $DP$,用记忆化来做. 设 ...

  9. iconfig1

    #include<iostream> using namespace std; //测试 template 里面是否还可以有 template class alloc{ }; templa ...

  10. [UVA11825]Hackers' Crackdown(状压dp)

    题解降智警告 吐槽降智警告 思路降智警告 代码降智警告 题目传送门 洛谷 果然水题做多了连半道难点的都能给咱干蒙... 水题做多了降智  --鲁迅 题目大意:见传送门 心路历程见末尾 正解(大概): ...