字典
一、认识字典
定义一个变量保存一个学生的信息
stu = {
'name': 'xiaoming',
'age': '18',
"tel": '13245',
'addrees': '成都'
1.字典和列表的选择;需要同时保存多个数据的时候,如果多个数据的意义相同就使用列表;如果多个数据的意义不同就使用字典;
2.认识字典(dict)
1)是容器数据类型;将{}作为字典容器的标志,里面多个 键值对用逗号隔开;{键1:值1,键2:值2…}
#键值对的格式:键:值
2)字典是可变的(支持增删改);字典是无序的(不支持下标,元素顺序不影响结果)
3)对元素的要求
字典的元素hi键值对
a.键的要求:键必须是不可变的类型的数据(数字、字符串、布尔、元组等);键是唯一的
b.值的要求:任何类型的数据
3.空字典
dict1 = {}
字典中的元素只能是键值对
dict2 = {'name': 'yang', 'age': 30}
print(dict2)
# dict3 = {'name':'yang',30} # 会报错,没有键值对
字典无序
print({'a': 10, 'b': 20} == {'b': 20, 'a': 10}) # -> True
键是不可变的类型的数据
dict3 = {10: 23, 1.23: 10, 'abc': 30, (1, 2): 50}
print(dict3)
# dict4 = {10: 23, 1.23: 10,'abc': 30, [1, 2]: 50} # 会报错
二、字典的基本操作
1.查 - 获取字典的值
1)查单个 - 一次获取一个值
#语法1 :字典[键] - 获取字典中指定键对应的值
#(键不存在的时候,运行会报错)
#语法2:
# 字典.get(键) - 获取字典中指定键对应的值
# (键不存在的时候,不会报错并且返回None)
# 字典.get(键,默认值)
# (键不存在的时候,不会报错并且返回默认值)
dog = {'name':'旺财','age':3,'breed':'中华田园犬','color':'白色'}
print(dog['age'])
2)遍历
#1)直接遍历
#for 键 in 字典:
# pass
#2)
#for 键,值 in字典.itmes():
# pass
2.列表的增删改
1)增/改 - 添加键值对
'''
1)字典[键] = 值 如果键存在就修改指定键对应的值;如果键不存在就添加键值对
2)字典.setdefault(键,值) 添加键值对(如果键不存在就添加键值对,如果键存在不动
'''
cat = {'name':'花花','breed':'加菲','color':'白色'}
2)修改
cat = {'name':'花花','breed':'加菲','color':'白色'}
cat['name'] = '小白'
print(cat) #-> {'name':'小白','breed':'加菲','color':'白色'}
3)添加
cat = {'name':'花花','breed':'加菲','color':'白色'}
cat['age'] = 3
print(cat) #-> {'name':'花花','breed':'加菲','color':'白色','age':3}
4)删除 - 删除键值对
'''
del 字典[键] - 删除指定键对应的键值对
字典.pop(键) - 取出指定键对应的值
'''
cat = {'name':'花花','breed':'加菲','color':'白色'}
del cat['age']
print(cat)
cat.pop('color')
print(cat)
三、字典相关操作和方法
1、相关操作
1)、字典不支持: + * > < >= <= 它只支持: == !=
2)、in 和 not in - 字典的in 和not in操作判断的是字典哄是否存在指定的键
2、相关函数
'''
len(字典) - 获取字典中键值对的个数
dict(数据) - 将指定数据转换成字典
对数据的要求:1.数据本身是一个序列
2.序列中的元素必须都是有且只有两个元素的小序列,
并且其中第一个元素是不可变的数据
'''
3、相关方法
#a.字典.clear()
# b.字典.copy()
# c.
# 字典.keys() - 返回一个序列,序列中的元素是字典所有的键
# 字典.values()- 返回一个序列,序列中的元素是字典所有的值
# 字典.items() - 返回一个序列,序列中的元素是字典的键和值组成的元组
# d.update
# 字典.update(序列) - 可以将序列中的元素全部添加字典中(序列必须是可以转换成字典的序列)
# 字典1.update(字典2)- 将字典2中所有的键值对都添加到字典1中
dict1 = {'a': 10,'b': 20}
dict2 = {'c': 100,'d':200}
dict1.update(dict2)
print(dict1)
四、字典推导式
''
{表达式1:表达式2 for 变量 in 序列}
'''
result = {x: x+1 for x in range(4)}
print(result)
练习题:
-
定义一个变量保存一个学生的信息,学生信心中包括:姓名、年龄、成绩(单科)、电话、性别
stu = {'name': '小明', 'age': 18, 'score': 88, 'tel': '1234567', 'gender': '男'}
-
定义一个列表,在列表中保存6个学生的信息(学生信息中包括: 姓名、年龄、成绩(单科)、电话、性别(男、女、不明) )
cla_stu = [{'name': '小明', 'age': 18, 'score': 88, 'tel': '1234567', 'gender': '男'}, {'name': '小芳', 'age': 17, 'score': 23, 'tel': '567890', 'gender': '女'}, {'name': '小王', 'age': 16, 'score': 90, 'tel': '134567', 'gender': '男'}, {'name': '小李', 'age': 19, 'score': 80, 'tel': '3234890', 'gender': '男'}, {'name': '小莉', 'age': 19, 'score': 45, 'tel': '765432', 'gender': '女'}, {'name': '小刚', 'age': 18, 'score': 85, 'tel': '45678', 'gender': '男'}] #1.统计不及格学生的个数 count = 0 for i in cla_stu: if i['score'] < 60: count += 1 print(count) #2.打印不及格未成年学生的名字和对应的成绩 nonage = {} for i in cla_stu: if i['score'] < 60 and i['age'] < 18 : print(i['name'],i['score']) #3.求所有男生的平均年龄 total_age = sum(i['age'] for i in cla_stu if i['gender'] == '男') num = 0 for _ in cla_stu: if _['gender'] == '男': num += 1 print(total_age/num) #4.打印手机尾号是8的学生的名字 for i in cla_stu: if int(i['tel']) % 10 == 8: print(i['name']) #5. 打印最高分和对应的学生的名字 max_score = 0 for i in cla_stu: if i['score'] > max_score: max_score = i['score'] for x in cla_stu: if x['score'] == max_score: print(x['name'],x['score']) #6.删除性别不明的所有学生 print([x for x in cla_stu if x['gender'] != '不明'])
- 将列表按学生成绩从大到小排序(挣扎一下,不行就放弃)
-
定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)
class_grade = [{'class_name': 'python2201', 'address': '第十二教室', 'class_teacher': [{'name': '张', 'gender': '女', 'tel': '1234567'}], 'lecturer': [{'name': '余', 'gender': '女', 'tel': '1234567'}], 'student': [{'name': '花花', 'age': '20', 'gender': '女', 'tel': '1234567'}, {'name': '明明', 'age': '22', 'gender': '男', 'tel': '1234567'}, {'name': '苗苗', 'age': '19', 'gender': '女', 'tel': '1234567'}, {'name': '丽丽', 'age': '21', 'gender': '女', 'tel': '1234567'}, {'name': '新新', 'age': '22', 'gender': '男', 'tel': '1234567'}, {'name': '翠翠', 'age': '20', 'gender': '男', 'tel': '1234567'}, {'name': '小刚', 'age': '18', 'gender': '男', 'tel': '1234567'}]} ]
-
已知一个列表保存了多个狗对应的字典:
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': '母'} ]
-
利用列表推导式获取所有狗的品种
print([i['breed'] for i in dogs ])
-
利用列表推导式获取所有白色狗的名字
print([i['name'] for i in dogs if i['color'] == '白色'])
-
给dogs中没有性别的狗添加性别为 ‘公’
for i in dogs: i.setdefault('gender','公') print(dogs)
-
统计 ‘银狐’ 的数量
count = 0 for i in dogs: if i['breed'] == '银狐': count += 1 print(count)
-