总结
字典
1. 认识字典
- 数据类型
- 是容器型数据类型
- 特点
- 可变的 – 支持增删改
- 无序的 – 没有下标
- 对元素的要求:
- 对键的要求: 键必须是不可变的类型数据(数字,字符串,布尔,元组)。键是唯一的!
- 对值的要求: 没有要求!
- 语法:
语法1:
字典[键] -- 获取字典中指定键对应的值,键不存在,报错!
语法2:
字典.get(键) -- 获取字典中指定键对应的值,键不存在,返回None
字典.get(键,默认值) -- 如果键存在返回键对应值,不存在才返回默认值
2. 字典的增删改
- 字典的增、改
- 字典[键] = 值 – 增、改
- 字典.setdefault(键,值) – 添加键值对(如果存在不动,不存在添加)
cat = {'name':'花花','breed':'加菲','color':'白色'}
cat['name'] = '小白'
cat['age'] = 2
print(cat)
- 字典的删
- del 字典[键] – 删除键值对
- 字典.pop(键) – 取出指定键对应值
cat = {'name':'花花','breed':'加菲','color':'白色'}
del cat['breed']
print(cat)
result = cat.pop('color')
print(cat,result)
3. 字典的相关操作
- 相关操作
- 字典不支持:+、*、>、<、>=、<= 但支持 ==、!=
- 字典支持in、not in ==> 键 in 字典
- 函数相关方法
-
len(字典) – 获取字典中键值对的个数
-
dict(数据) – 将数据转换成字典
-
对数据的要求:1.本身是一个序列
2.序列中的元素必须都是有且仅有两个元素的小序列,并且其中第一个元素是不可变的数据
-
- 相关方法
- 字典.clear() – 清空字典
- 字典.copy() – 拷贝字典
- 字典.keys() – 返回一个序列,序列中的元素是字典中所有的 键!!!
- 字典.value() – 返回一个序列,序列中的元素是字典所有的 值!!!
- 字典.items() – 返回一个序列,序列中的是字典中所有的 键值!!!
- 字典.update(序列) – 将序列中的元素一次性添加多个元素 (更新)
4.字典的推导式
- {键:值 for 变量 in 序列}
result = {i:i*2 for i in range(5)}
print(result)
result = {i:i for i in range(10) if i % 3}
print(result)
作业
- 定义一个变量保存一个学生的信息,学生信心中包括:姓名、年龄、成绩(单科)、电话、性别
student1 = {
'name':'小宇',
'age':22,
'score':90,
'tel':'111',
'sex':'女'
}
-
定义一个列表,在列表中保存6个学生的信息(学生信息中包括: 姓名、年龄、成绩(单科)、电话、性别(男、女、不明) )
student = [ {'name':'张三','age':18,'score':90,'tel':'123','sex':'女'}, {'name':'李四','age':22,'score':60,'tel':'128','sex':'男'}, {'name':'王五','age':26,'score':58,'tel':'129','sex':'女'}, {'name':'老刘','age':14,'score':23,'tel':'128','sex':'女'}, {'name':'老郭','age':12,'score':88,'tel':'129','sex':'不明'} ]
- 统计不及格学生的个数
count = 0 for stu in student: if stu['score'] < 60: count += 1 print(count)
- 打印不及格未成年学生的名字和对应的成绩
for stu in student: if stu['age'] < 18 and stu['score'] < 60: print(stu['name'],stu['score'])
- 求所有男生的平均年龄
sum1 = 0 for stu in student: sum1 += stu['age'] print(sum1/len(student))
- 打印手机尾号是8的学生的名字
for stu in student: if stu['tel'][-1] == '8': print(stu['name'])
- 打印最高分和对应的学生的名字
max_score = max(i['score'] for i in student) max_name = {i['name'] for i in student if max_score == i['score']} print(max_name)
- 删除性别不明的所有学生
for stu in student: if not (stu['sex'] == '不明'): print(stu)
- 将列表按学生成绩从大到小排序(挣扎一下,不行就放弃)
for i in range(1,len(student)): for j in range(0,len(student)-i): if student[j]['score'] < student[j+1]['score']: student[j],student[j+1] = student[j+1],student[j] print(student)
-
定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)
-
已知一个列表保存了多个狗对应的字典:
dogs = [ {'name': '贝贝', 'color': '白色', 'breed': '银狐', 'age': 3, 'gender': '母'}, {'name': '花花', 'color': '灰色', 'breed': '法斗', 'age': 2}, {'name': '财财', 'color': '黑色', 'breed': '土狗', 'age': 5, 'gender': '公'}, {'name': '包子', 'color': '黄色', 'breed': '哈士奇', 'age': 1}, {'name': '可乐', 'color': '白色', 'breed': '银狐', 'age': 2}, {'name': '旺财', 'color': '黄色', 'breed': '土狗', 'age': 2, 'gender': '母'} ]
1. 利用列表推导式获取所有狗的品种
> ['银狐', '法斗', '土狗', '哈士奇', '银狐', '土狗']
result = [i['breed'] for i in dogs]
print(result)
2. 利用列表推导式获取所有白色狗的名字
> ['贝贝', '可乐']
result = [i['name'] for i in dogs if i['color']=='白色']
print(result)
3. 给dogs中没有性别的狗添加性别为 '公'
result = [i.setdefault('gender','公') for i in dogs]
print(result)
4. 统计 ‘银狐’ 的数量
count = 0
for i in dogs:
if i['breed'] == '银狐':
count += 1
print(count)