字典相关操作
* 类型转换:dict() 字典的转换一般不使用关键字 而是自己动手转
1.按k取值(不推荐使用)
按内置方法get取值(推荐使用)
修改值数据
新增键值对
删除数据
统计字典中键值对的个数
字典三剑客
补充说明
当第二个公共值是可变类型的时候 一定要注意 通过任何一个键修改都会影响所有
元组相关操作
* 类型转换tuple 支持for循环的数据都可以转成元组
* 元组必须掌握的方法
t1 = (11, 22, 33, 44, 55, 66)
1.索引取值
2.切片操作
3.间隔、方向
4.统计元组内数据值的个数
5.统计元组内某个数据值出现的次数
6.统计元组内指定数据值的索引值
7.元组内如果只有一个数据值那么逗号不能少
8.元组内索引绑定的内存地址不能被修改(注意区分 可变与不可变)
9.元组不能新增或删除数据
集合相关操作
* 类型转换 set()
集合内数据必须是不可变类型(整型 浮点型 字符串 元组)
集合内数据也是无序 没有索引的概念
* 集合需要掌握的方法有:去重和关系运算
* 去重
* 关系运算
字符编码理论
该知识点理论特别多 但是结论很少 代码使用也很短
1.字符编码只针对文本数据
2.回忆计算机内部存储数据的本质
3.既然计算机内部只认识01 为什么我们却可以敲出人类各式各样的字符
肯定存在一个数字跟字符的对应关系 存储该关系的地方称为>>>:字符编码本
4.字符编码发展史
4.1.一家独大
计算机是由美国人发明的 为了能够让计算机识别英文
需要发明一个数字跟英文字母的对应关系
ASCII码:记录了英文字母跟数字的对应关系
用8bit(1字节)来表示一个英文字符
4.2.群雄割据
中国人GBK码:记录了英文、中文与数字的对应关系
用至少16bit(2字节)来表示一个中文字符
很多生僻字还需要使用更多的字节
英文还是用8bit(1字节)来表示
日本人shift_JIS码:记录了英文、日文与数字的对应关系
韩国人Euc_kr码:记录了英文、韩文与数字的对应关系
每个国家的计算机使用的都是自己定制的编码本
不同国家的文本数据无法直接交互 会出现"乱码"
4.3.天下一统
unicode万国码兼容所有国家语言字符 起步就是两个字节来表示字符
utf系列:utf8 utf16 ...
专门用于优化unocide存储问题
英文还是采用一个字节 中文三个字节
字符编码实操
* 针对乱码不要紧张 尝试切换编码就可以
* 编码::将人类的字符按照指定的编码编码成计算机能够读懂的数据 字符串.encode()
* 解码:将计算机能够读懂的数据按照指定的编码解码成人能够读懂 bytes类型数据.decode()
* python2与python3差异
python2默认的编码是ASCII
1.文件头 encoding:utf8
2.字符串前面加u u'你好啊'
python3默认的编码是utf系列(unicode)
1.优化员工管理系统
拔高: 是否可以换成字典或者数据的嵌套使用完成更加完善的员工管理而不是简简单单的一个用户名(能写就写不会没有关系)
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('请输入员工姓名>>>:').strip()
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 of info------------------
编号:{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: # {}
# 4.格式化输出员工数据
print(f"""
--------------------emp of info------------------
编号:{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_delete_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('输入不合法!!!')
2.去重下列列表并保留数据值原来的顺序
eg: [1,2,3,2,1] 去重之后 [1,2,3]
l1 = [2,3,2,1,2,3,2,3,4,3,4,3,2,3,5,6,5]
3.有如下两个集合,pythons是报名python课程的学员名字集合,linuxs是报名linux课程的学员名字集合
pythons={'jason','oscar','kevin','ricky','gangdan','biubiu'}
linuxs={'kermit','tony','gangdan'}
1. 求出即报名python又报名linux课程的学员名字集合
2. 求出所有报名的学生名字集合
3. 求出只报名python课程的学员名字
4. 求出没有同时这两门课程的学员名字集合
4.统计列表中每个数据值出现的次数并组织成字典战士
eg: l1 = ['jason','jason','kevin','oscar']
结果:{'jason':2,'kevin':1,'oscar':1}
真实数据
l1 = ['jason','jason','kevin','oscar','kevin','tony','kevin']
题外话
感兴趣的小伙伴,赠送全套Python学习资料,包含面试题、简历资料等具体看下方。
👉CSDN大礼包🎁:全网最全《Python学习资料》免费赠送🆓!(安全链接,放心点击)
一、Python所有方向的学习路线
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。
二、Python必备开发工具
工具都帮大家整理好了,安装就可直接上手!
三、最新Python学习笔记
当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。
四、Python视频合集
观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
五、实战案例
纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
六、面试宝典
👉CSDN大礼包🎁:全网最全《Python学习资料》免费赠送🆓!(安全链接,放心点击)
若有侵权,请联系删除