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.格式化输出员工数据
        printf"""
        编号:{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')
posted @   空白o  阅读(39)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示