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

⽂件内容: 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. centos7.5 时间设置

    # ----- 设置时间同步+时区(上海) ----- rpm -qa ntp || yum -y install ntp systemctl enable ntpd timedatectl set- ...

  2. leetcode 813. Largest Sum of Averages

    对于一个数组中的数进行分组,取每个组里的平均值进行加和的. 使用动态规划,其中dp[i][k]表示以i为结尾的有k个分组的,那么递推式为: dp[i][k]=dp[j][k-1]+(sum[i]-su ...

  3. 同时使用多个JDK版本的方法

    开发环境需要使用JDK1.8,但是有些系统仅支持JDK1.6,以下方法可满足此需求: 1.使用安装包安装JDK1.6,安装之后记得设置不自动更新,控制面板-JAVA:        2.使用免安装版J ...

  4. freemarker demo

    <!--freemarker--> <dependency> <groupId>org.springframework.boot</groupId> & ...

  5. 跨域访问技术CORS(Cross-Origin Resource Sharing)简介

    为什么要用CORS? CORS是一个W3C标准,全称是"跨域资源共享"(Cross-origin resource sharing). 它允许浏览器向跨源服务器,发出XMLHttp ...

  6. 引擎设计跟踪(九.14.2 final) Inverse Kinematics: CCD 在Blade中的实现

    因为工作忙, 好久没有记笔记了, 但是有时候发现还得翻以前的笔记去看, 所以还是尽量记下来备忘. 关于IK, 读了一些paper, 觉得之前翻译的那篇, welman的paper (http://gr ...

  7. 自定义事件——Event和CustomEvent

    之前在学习自定义事件时,在MDN的Event.initEvent()页面顶端有写:该特性已从Web标准中删除,虽然一些浏览器目前仍然支持它,但也许会在未来的某个时间停止支持,请尽量不要使用该特性. 作 ...

  8. python面试题--数据类型

    数据类型 字典 dict:字典,字典是一组键(key)和值(value)的组合,通过键(key)进行查找,没有顺序, 使用大括号”{}”;应用场景:dict,使用键和值进行关联的数据; 现有字典d={ ...

  9. Eclipse中Java build path的使用

    1.Eclipse中,工程属性的Java Build Path的Library标签页下,有如下几个按钮:Add Jars...添加JAR包,是指本Eclipse当前包含的工程中的,在工程列表下选取即可 ...

  10. android studio 升级到3.3.1后,提示程序包不存在

    android studio 升级到3.3.1后,提示程序包不存在 原因 主Module--A 引用了其他Moduel--B里的jar库, 只需要把B的dependencies改成如下(implent ...