python学习笔记
今日内容概要
- 作业讲解
- 文件的读写模式
- 文件的操作模式
- 文件操作的诸多方法
今日内容详细
作业讲解
1.统计列表中每个数据值出现的次数并组织成字典战士
eg: l1 = ['jason','jason','kevin','oscar']
结果:{'jason':2,'kevin':1,'oscar':1}
真实数据
l1=['jason','jason','kevin','oscar','kevin','tony','kevin']
data_dict = {} # 1.先定义一个空字典
for name in l1: # 2.先循环获取到列表中的每一个数据值
if name not in data_dict: # 3.判断当前数据值是否已经存在于字典的k中
data_dict[name] = 1 # 4.如果不存在,则新增一个键值对(第一次出现)
else:
data_dict[name] += 1 # 5.如果存在,则让该键对应的值自增1(重复出现)
print(data_dict)
2.编写员工管理系统
1.添加员工信息
2.修改员工薪资
3.查看指定员工
4.查看所有员工
5.删除员工数据
提示:用户数据有编号、姓名、年龄、岗位、薪资
数据格式采用字典:思考如何精准定位具体数据>>>:用户编号的作用
# 4.定义存储用户数据的字典
data_dict = {} # {'1':{}, '2':{}, '3':{}}
# 1.先搭建功能框架
while True:
print("""
1.添加员工信息
2.修改员工薪资
3.查看指定员工
4.查看所有员工
5.删除员工数据
""")
# 2.获取用户输入的功能编号
func_id = input('请输入功能的编号:').strip()
# 3.判断用户输入的功能编号
if func_id == '1':
# 5.获取用户数据
emp_id = input('请输入员工编号:').strip()
# 9.针对员工编号应该做不重复校验
if emp_id in data_dict:
print('该员工编号已经存在')
continue
emp_name = input('请输入员工姓名:').steip()
emp_age = input('请输入员工年龄:').strip()
emp_job = input('请输入员工岗位:').strip()
emp_salary = input('请输入员工薪资:').strip()
# 6.构造存储用户数据的小字典
temp_dict = {}
# 7.将员工数据全部录入该小字典
temp_dict['emp_id'] = emp_id
temp_dict['emp_name'] = emp_name
temp_dict['emp_age'] = emp_age
temp_dict['emp_job'] = emp_job
temp_dict['emp_salary'] = emp_salary
# 8.将员工数据小字典当做大字典的值添加
data_dict[emp_id] = temp_dict # {'1':{}}
elif func_id = '2':
# 1.获取员工编号
target_emp_id = input('请输入想要修改的员工编号:').strip()
# 2.判断当前员工编号是否存在
if target_emp_id not in data_dict:
print('当前员工编号不存在,无法修改')
continue
# 3.根据员工编号获取该员工的详细数据(小字典)
emp_data = data_dict.get(target_emp_id) # {}
# 4.获取新的员工薪资
new_salary = input('请输入该员工新的薪资:')。strip()
# 5.修改员工小字典中薪资对应的值
emp_data['emp_salary'] = new_salary
# 6.将修改之后的小字典重新赋值到大字典中
data_dict[target_emp-id] = emp_data
# 7.人性化提示
print(f'员工编号:{target_emp_id} 员工姓名:{emp_data.get("emp_name")}薪资修改成功')
elif func_id == '3':
# 1.获取员工编号
target_emp_id = input('请输入想要查询的员工编号:').strip()
# 2.判断当前编号是否存在
if target_emp_id not in data_dict:
print('当前员工编号不存在')
continue
#3.根据员工编号获取员工数据字典
emp_data = data_dict.get(target_emp_id)
#4.格式化输出员工数据
print(f"""
编号:{emp_data.get('emp_id')}
姓名:{emp_data.get('emp_name')}
年龄:{emp_data.get('emp_age')}
岗位:{emp_data.get('emp_job')}
薪资:{emp_data.get('emp_salary')}
""")
elif func_id == '4':
# 1.获取所有员工数据小字典
all_emp_data = data_dict.values() # [{},{},{}]
# 2.循环获取每一个员工数据字典
for emp_data in all_emp_data: # {}
#3.格式化输出员工数据
print("""
编号:{emp_data.get('emp_id')}
姓名:{emp_data.get('emp_name')}
年龄:{emp_data.get('emp_age')}
岗位:{emp_data.get('emp_job')}
薪资:{emp_data.get('emp_salary')}
""")
elif func_id == '5':
# 1.获取想要删除的员工编号
target_delata_id = input('请输入想要删除的员工编号:').strip()
# 2.判断员工编号是否存在
if target_ delete_id not in data_dict:
print('员工编号不存在')
continue
# 3.根据员工编号删除键值对
data_dict.pop(target_delete_id)
# 4.小提示
print(f'员工编号{target_delete_id}数据删除成功')
else:
print('请按要求输入')
文件读写模式
补充知识
1.with语法支持一次性打开多个文件
with open(r'a.txt', 'r', encoding='utf8') as f1, open(r'b.txt', 'r', encoding='utf8') as f2, open() as f3, open() as f4...:
2.补全python语法,但是不执行任何操作
pass:推荐使用
...:不推荐使用
3.通常情况下英语单词的结尾如果跟上了able表示具备该单词描述的能力
readable:具备读取内容的能力
writable:具备填写内容的能力
r:只读模式 默认的模式
使用该模式打开的文件只能读取内容,不能做其他操作(写)
# 文件路径不存在:r模式直接报错
# 文件路径存在:r模式会打开文件等待读取文件内容
with open(r'a.txt', 'r', encoding='utf8') as f:
print(f.read())
w:只写模式
使用该模式打开的文件只能写内容,不能做其他操作(读)
# 文件路径不存在:w模式会自动创建该文件
# 文件路径存在:w模式会先清空该文件内容,之后等待填写新内容
with open(r'a.txt', 'w', encoding='utf8') as f:
pass
a:只追加写模式
使用该模式打开的文件默认是在末尾追加新的内容,不能做其他操作(读)
# 文件路径不存在:a模式会自动创建该文件
# 文件路径存在:a模式不会先清空该文件内容只在文件末尾等待填写新内容
with open(r'a.txt', 'a', encoding='utf8') as f:
pass
文件的操作模式
t:文本模式
文件操作的默认模式
r:rt
w: wt
a:at
1.只能操作文本文件
2.必须指定encoding
3.读写都是以字符串为单位
b:二进制模式
必须自己指定不能省略
r:rb
w:wb
a:ab
1.能够操作所有类型的文件
2.不需要指定encoding参数
3.读写都是以bytes为单位
文件的操作的诸多方法
# 当文件数据较大的时候,不推荐一次性读取
for line in f:
print(line) # 文件对象支持for循环一次只读一行
read()一次性读取文件内容并且光标会停留在文件末尾,继续读则为空
readline()一次只读一行内容
readlines()按照行的方式读取所有的内容并组织成列表返回
readable()判断当前文件是否可读
writable()判断当前文件是否可写
write()填写文件内容
writelines()支持填写容器类型(内部可以存放多个数据值的数据类型)多个数据值
flush()将内存中的文件数据立刻刷到硬盘(主动按ctrl+s)
作业
1.编写简易版本的拷贝工具
自己输入想要拷贝的数据路径 自己输入拷贝到哪个地方的目标路径
任何类型数据皆可拷贝
ps:个别电脑C盘文件由于权限问题可能无法拷贝 换其他盘尝试即可
file1 = input('想要拷贝的数据路径:').strip() #获取想要拷贝的数据路径
file2 = input('拷贝到哪的目标路径:').strip() #获取拷贝到哪个地方的目标路径
with open (r'%s' %file1, 'rb') as read_f, open(r'%s' %file2, 'wb') as write_f:
for line in read_f:
write_f.write(line)
- 2.利用文件充当数据库编写用户登录、注册功能
文件名称:userinfo.txt
基础要求:
用户注册功能>>>:文件内添加用户数据(用户名、密码等)
用户登录功能>>>:读取文件内用户数据做校验
ps:上述功能只需要实现一次就算过关(单用户) 文件内始终就一个用户信息
拔高要求:
用户可以连续注册
用户可以多账号切换登录(多用户) 文件内有多个用户信息
ps:思考多用户数据情况下如何组织文件内数据结构较为简单
提示:本质其实就是昨天作业的第二道题 只不过数据库由数据类型变成文件
while True:
print("""
1.用户注册功能
2.用户登录功能
""")
choice = input('please in your command:')
if choice == '1':
name = input('username:').strip()
pwd = input('password:').strip()
with open(r'D:\pythonProject\userinfo.txt', 'a', encoding='utf8') as f:
info = '%s, %s' % (name, pwd)
f.write(info)
elif choice == '2':
name = input('username:').strip()
pwd = input('password:').strip()
with open(r'D:\pythonProject\userinfo.txt', 'r', encoding='utf8') as f:
f1 = f.read()
if name == f1.split(',')[0] and pwd == f1.split(',')[1]:
print('cg')
else:
print('sb')
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了