Python3模拟登录操作实例分析
作者:爱跳舞的青年君 发布时间:2022-01-18 13:36:26
标签:Python3,模拟登录
本文实例讲述了Python3模拟登录操作。分享给大家供大家参考,具体如下:
模拟登录_要求:
1. 用户输入账号密码进行登录
2. 用户信息保存在文件内
3. 用户密码输入错误三次后锁定用户
逻辑图:
代码:
#!/usr/bin/env python3
# Author:Robert
# --*-- coding: utf-8 --*--
count = 0 #记录试错次数,计数项赋初始值
load = True #完成功能后退出,赋初始值
file = open("用户信息文件.txt",'r',encoding='utf-8')
file_lock = open("锁定用户信息文件.txt",'r+',encoding='utf-8')
line = eval(file.readline()) #将正确信息中的字符串转换成字典(原字符串为字典格式)
line_list = eval(file_lock.readline()) #将正确信息中的字符串转换成列表(原字符串为列表格式)
def out(): #定义重复代码,目的是帮助跳出while循环并关闭已打开的文档
global load
load = False #赋值load,为了跳出while循环
file_lock.close() #关闭正确用户信息文档
file.close() #关闭锁定用户信息文档
while load: #判断是否已完成功能
name = input("请输入用户名:")
password = input("请输入密码:")
if name in line and name not in line_list: #判断用户名是否正确,是否已被锁定
while count < 3:
if password == line[name]: #判断用户名是否对应正确的密码
print("您已成功登录")
out() #调用定义out方法
break
else: #说明未输入的正确的密码
count +=1
msg_count = '第%s次密码输入错误\n'%(count) #提示输入错误次数
print(msg_count)
if count < 3: #小于三次错误的输入,可以重新输入
password = input("密码错误,请重新输入密码:") #重新输入密码
elif count == 3: #判断是否已输错三次
print("已输错3次,账号已锁定")
line_list.append(name) #将已锁定信息加入锁定元组中
file_lock.seek(0) #输入指针移到开头,如果不移动会产生多个元组
file_lock.write(str(line_list)) #写入锁定信息
file_lock.tell() #获取当前的输入指针位置,如果不获取会产生多个元组
out()
break
elif name in line_list: #判断用户名是否在已锁定用户名中
print("该用户名已被锁定")
out()
break
else: #说明用户名不在正确用户名信息中
print("该用户名不存在")
out()
用户信息文件.txt
{"name":"password","XiaoMing":"123456","Robert":"234567","Alex":"345678","haha":"123","hahage":"123","hahage2":"123","hahage3":"123"}
锁定用户信息文件.txt
['name']
希望本文所述对大家Python程序设计有所帮助。
来源:https://blog.csdn.net/weixin_39099836/article/details/78388688


猜你喜欢
- 一、要求 1 创建数据表 CREATE TABLE [dbo].[StuScore]( [stuid] [int] NOT NULL, [s
- 上图代码# -*- coding: utf-8 -*-"""Created on Sun Jun 18 20:
- 如下所示:depot_name = models.CharField( u'设备库房名称', bla
- MySQL采用了基于开销的优化器,以确定处理查询的最解方式。在很多情况下,MySQL能够计算最佳的可能查询计划,但在某些情况下,MySQL没
- 在 TypeScript 中一共有 7 种基本类型。1、booleanvar isDone: boolean = false;2、numbe
- 一 MySQL WorkbenchMySQL Workbench提供DBAs和developers一个集成工具环境:1)数据库设计和建模2)
- MySQL 临时表在我们需要保存一些临时数据时是非常有用的。临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间。临时
- 概述在本文中,我们将以深度库即 Mediapipe为基础库,以及其他计算机视觉预处理的CV2库来制作手部地标检测模型。市场上有很多关于这种问
- PDOStatement::errorInfoPDOStatement::errorInfo — 获取跟上一次语句句柄操作相关的扩展错误信息
- 在ASP中,FSO的意思是File System Object,即文件系统对象。
- 今天发现有一个备份的mysql数据文件夹异常变大,一查发现是多了三个文件:ibdata1 ib_logfile0 ib_logfile1,前
- 导言本文简单介绍了如何从网易财经获取某支股票的价格数据,并根据价格数据画出相应的日K线图。有助于新手了解并使用Python的相关功能。包括列
- 要想创建一个iterator,必须实现一个有__iter__()和__next__()方法的类,类要能够跟踪内部状态并且在没有元素返回的时候
- 一、从外部文档中粘贴时,如果只要文字而不想要其格式,可以使用“Edit→paste as text”命令,不要直接用Ctrl+V。二、当有浏
- python使用folium 库生成地图网页的具体代码,供大家参考,具体内容如下folium 官网import foliumimport p
- JavaScript substr 方法substr 方法用于根据开始位置和长度截取字符串并返回截取部分字符串。其语法如下:str_obje
- Python时间处理Python在处理与时间相关的操作时有两个重要模块:time和datetime。在本文中,我们介绍这两个模块并为每个场景
- 具体代码如下所示:#coding=utf-8__author__ = 'Eagle'import osimport time
- 最近在使用NFineBase框架+c#做一个系统的时候,在使用sql server 2012 连接数据库的时候 ,遇到几个问题。一.就是在本
- 前言我们先说一下思路:先对目标网站发送请求,获取html源码,然后对源码里面的所以图片链接进行筛选,然后再次对图片链接发送请求,然后保存。思