一、统计⽂件数据中出现的的所有字符与该字符出现的个数(不区分⼤⼩写,标点与空格也算)

⽂件内容: hello friend, can you speak English!
# 结果:
{
'h': 1,
'e': 4,
'l': 3,
'o': 2,
' ': 5,
...
}  

代码如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*- #统计⽂件数据中出现的的所有字符与该字符出现的个数
#字符串方式
char_dict1 = {}
with open('test.txt', 'r', encoding='utf-8')as f:
f_str = f.read()
for k1 in f_str:
char_dict1[k1.lower()] = f_str.lower().count(k1.lower())
print(char_dict1) #seek方式
char_dict2 = {}
with open('test.txt', 'r', encoding='utf-8')as f2:
for k2 in f2.read():
f2.seek(0,0)
char_dict2 [k2.lower()] = f2.read().lower().count(k2.lower())
print(char_dict2 ) #列表方式
char_dict3={}
char_lsit=list()
with open('test.txt', 'rt',encoding='utf-8')as f:
for k5 in f.read():
char_lsit.append(k5.lower())
f.seek(0, 0)
for k6 in f.read():
if k6 in char_lsit:
char_dict3[k6]=char_lsit.count(k6)
print(char_dict3)  

二、 统计⽂件中⼤写字⺟、⼩写字⺟、数字及其他字符出现的次数

# ⽂件内容: Abc123,-+XYZopq000.?/
# 结果:
{
'⼤写字⺟': 4,
'⼩写字⺟': 5,
'数字': 6,
'其他字符': 6
}  

代码如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*- #统计⽂件中⼤写字⺟、⼩写字⺟、数字及其他字符出现的次数
capital_count=0
lowercase_count=0
number_count=0
special_characters_count=0
with open('test2.txt','rt',encoding='utf-8') as f:
string=f.read()
for i in string:
if (ord(i) >= 33 and (ord(i)<= 47)) or ((ord(i) >= 58 and (ord(i)<= 64) )):
special_characters_count += 1
elif ord(i) >= 48 and (ord(i)<= 57):
number_count += 1
elif ord(i) >= 65 and (ord(i)<= 90):
capital_count += 1
elif ord(i) >= 97 and (ord(i)<= 122):
lowercase_count += 1
string_count = {'大写字母':capital_count, '小写字母':lowercase_count, '数字':number_count, '特殊字符':special_characters_count}
print(string_count)

三、登录注册系统

# 需求分析:
1.可以循环登录注册,输⼊1代表选择登录功能,输⼊2代表注册功能,输⼊0代表退出,其他输⼊代表
输⼊有误,重输
2.⽤户的账号密码信息存放在usr.txt⽂件中,保证⽤户注册成功后,重启系统,⽤户信息仍然保存
3.登录在账号验证通过才输⼊密码验证登录,账号验证三次失败⾃动进⼊注册功能,登录三次验证失败
⾃动退出系统
4.第⼀次注册,⽂件写⼊ 账号:密码 信息,再次注册追加写⼊ |账号:密码 信息  

代码如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import time
white_user_set=[]
black_user_set=[]
user_list=[]
white_userDB='userDB'
black_userDB='user_blackDB' with open(black_userDB, 'r+',encoding='utf-8') as black_f:
for black_user in black_f.readlines():
black_user = black_user.strip("\n")
black_user_set.append(black_user) with open(white_userDB, 'r+') as white_f:
for file in white_f.readlines():
file = file.strip("\n")
user_field,passwd_field,remarks_field= file.split('|')
name1_field, user=user_field.split(':')
name2_field, passwd = passwd_field.split(':')
name3_field, remarks = remarks_field.split(':')
white_user_set.append({name1_field:user,name2_field:passwd,name3_field:remarks})
user_list.append(user)
print(white_user_set) def mod_info(file_name,old_str,new_str):
mod_date=''
with open(file_name,'r+',encoding='utf-8') as f:
for line in f:
line = line.replace(old_str,new_str)
mod_date += line
with open(file_name, 'w', encoding='utf-8') as f1:
f1.writelines(mod_date) #用户注册函数
def user_register():
count=0
while True:
count+=1
register_name = input('创建用户名:')
register_passwd = input('创建密码:')
register_passwd1 = input('创建密码:')
user_remarks = input('输入您的备注信息,默认为空:')
if user_remarks == '':
user_remarks = 'null'
if register_passwd == register_passwd1:
if register_name in user_list:
print('用户已存在,请重新创建')
else:
user_information=register_name+':'+register_passwd+':'+user_remarks
print(user_information)
print(type(user_information))
with open(white_userDB,'a+') as f:
f.write('\n')
f.write(user_information)
print('恭喜您,用户创建成功!!!')
return 0
else:
if count == 3:
print('失败次数超过上限,程序退出')
exit(3)
print('两次密码不一致,请重新创建2')

#用户登录函数
def user_login():
Flag = True
user_failures = 0
all_failures = 0
while Flag:
login_name = input('请输入用户名:')
login_passwd = input('输入密码:')
print(login_name,login_passwd)
if login_name in black_user_set:
print('该用户已被锁定,请联系您的管理员!')
exit(3)
if login_name in user_list:
for subscript,line in enumerate(white_user_set):
if (login_name == line['name']) and (login_passwd == line['passwd']):
print('登录成功')
print('正在登录。请稍后')
time.sleep(1)
print('')
print('='*30)
print('欢迎来到 250 世界')
print('='*30)
Flag = False
break
for subscript,line in enumerate(white_user_set):
if (login_name == line['name']) and (login_passwd != line['passwd']):
user_failures += 1
all_failures += 1
if (user_failures == 3):
print('验证失败次数过多,用户被锁定')
with open(black_userDB,'a+') as f:
f.write(login_name+'\n')
exit(2)
print('用户名或密码不正确,登录失败,请重新登录 2 ')
break
else:
print('用户名或密码不正确,登录失败,请重新登录 3 ')
all_failures += 1
if all_failures == 6:
print('失败次数过多,请确认后再登录 4')
exit(1) #用户信息修改函数
def user_info_mod(user_name,user_passwd,remarks):
user_login
print('''
1.修改密码
2.修改备注信息
''')
info=input('请根据提示,选择您要修改的用户信息')
if info == '1':
confirm_password = input('请输入您当前的密码:')
new_password = input('请输入您要修改的密码:')
if confirm_password == user_passwd:
print('您输入的当前密码有误,请程序输入!')
else:
for subscript, line in enumerate(white_user_set):
if (user_name == line['name']):
line[passwd]=new_password
mod_info(white_userDB, confirm_password, new_password )
elif info == 2:
new_remarks=input('请输入您要修改的备注:')
for subscript, line in enumerate(white_user_set):
if (user_name == line['name']):
line[remarks]=new_remarks
mod_info(white_userDB, line[remarks], new_remarks)
else:
print('无效的输入,请重新输入!') #主函数
def main():
while True:
count=0
print('1 注册用户:')
print('2 登录系统:')
print('3 修改备注信息:')
user_operation=input('请选择您的操作:')
print(type(user_operation))
if user_operation == '1' or user_operation == '3':
user_register()
break
elif user_operation == '2':
user_login()
break
else:
count+=1
if count == 3:
print('失败次数过多,请确认后再登录')
exit(3)
print('非法的输入,请重试') if __name__ == '__main__':
main()

  

Python课程第三天作业的更多相关文章

  1. 2003031121-浦娟-python数据分析第三周作业-第一次作业

    项目 内容 课程班级博客链接 https://edu.cnblogs.com/campus/pexy/20sj 作业链接 https://edu.cnblogs.com/campus/pexy/20s ...

  2. python课程单元三编程题讲解(上)

    目录 1.快乐的数字 2.凯撒密码I 3.凯撒密码II 4.括号配对检测 A @     下面向大家介绍一下我在学习python课程的一些题目的解法,如果大家有什么更好的解法请私信我.这里只显示题目与 ...

  3. Python课程第五天作业

    1.利用字典推导式和列表推导式完成数据的相互转化: dic = {'name': 'Owen', 'age': 18, 'gender': '男'} ls = [('name', 'Owen'), ( ...

  4. python课程第三周重点记录

    1.关于set,set是一个无序且不重复的元素集合 s = set(["ss","dd","pp"]) #创建set s1 = set([& ...

  5. Python课程第四天作业

    1.定义一个函数,该函数可以实现控制台输入,最终返回一个int类型的正整数 def chr_to_int(): user_input = input('请输您要转换的字符串:') if user_in ...

  6. BUAA OO 2019 第三单元作业总结

    目录 总 JML规格化设计 理论基础 工具链 规格验证 验证代码 代码静态检查 自动生成测试样例 生成结果 错误分析 作业设计 第九次作业 架构 代码实现 第十次作业 架构 代码实现 第十一次作业 架 ...

  7. Java课程设计——博客作业教学数据分析系统(201521123082 黄华林)

    Java课程设计--博客作业教学数据分析系统(201521123082 黄华林) 一.团队课程设计博客链接 博客作业教学数据分析系统(From:网络五条狗) 二.个人负责模块或任务说明 1.网络爬虫 ...

  8. OO课程第三次总结QWQ

    调研,然后总结介绍规格化设计的大致发展历史和为什么得到了人们的重视 emmm为这个问题翻遍百度谷歌知乎也没有得到答案,那我就把自己认为最重要的两点简要说明一下吧,欢迎大家补充~ 1.便于完成代码的重用 ...

  9. OO第一单元三次作业总结

    写在前面 第一单元作业是针对输入的多项式进行格式合法判断,然后进行求导,结果长度优化,最后输出.三次难度递增,不断添加新的需求,总体感觉在实现方面没有多大困难(?),个人主要困扰环节是寻找自己未知bu ...

随机推荐

  1. ZoomCharts

    net chart 配置links没有id的话,画图的links会丢失

  2. vue 基础: 组件

    2.局部组件: 动态组件:

  3. Byte数组和字符串相互转换的问题

    第一:需求:将文件转成byte数组,之后转成字符串返回.过滤器接收到响应内容后,需要将响应的内容转成byte数组. 第二:我刚开始的做法: Controller:byteArr = Conversio ...

  4. 作业二:构建swap函数

    一.swap代码 #include<stdio.h> int main() //主函数部分 { void swap(int *m,int *n); int a,b; int *p1,*p2 ...

  5. java项目---用java实现二叉平衡树(AVL树)并打印结果(详)(3星)

    package Demo; public class AVLtree { private Node root; //首先定义根节点 private static class Node{ //定义Nod ...

  6. 17. Debuggers (调试器 5个)

    反编译是安全研究的重要组成部分. 它将帮助您解剖Microsoft补丁,以发现他们无法告诉您的默认修复的错误,或更仔细地检查服务器二进制文件以确定为什么您的漏洞利用不起作用. 许多调试器都可用,但ID ...

  7. 命令行编译多个java文件

    如何使用命令行编译多个java文件 文件结构: method 1 cd javaproject javac -sourcepath javapath -d classpath javapath/*.j ...

  8. WinForm控件开发总结目录

    WinForm控件开发总结(一)------开篇 WinForm控件开发总结(二)------使用和调试自定义控件 WinForm控件开发总结(三)------认识WinForm控件常用的Attrib ...

  9. day061 cookie和session

    一. cookie 1.cookie 的原理 工作原理是:浏览器访问服务端,带着一个空的cookie,然后由服务器产生内容, 浏览器收到相应后保存在本地:当浏览器再次访问时,浏览器会自动带上Cooki ...

  10. zabbix升级遇到连接不上数据库的问题

    问题 迁移zabbix-server端时,原来是4.0版本,现在为4.2版本,遇到如下问题       解决办法 update dbversion set mandatory=;