1. 使用多个变量同时获取列表或者元组的元素
要求变量的个数必须和元组/列表元素的个数保持一致
t1 = (10, 20, 30, 40)
a, b, c, d = t1
print(a, b, c, d)
point = (10, 89)
x, y = point
2.使用多个变量同时获取列表或者元组的元素
当变量的个数小于元素的个数的时候,必须在某一个变量前加*
获取的时候先让不带的变量按照顺序获取对应的数据,把剩下的全部保存到带的变量中。
*x, y = t1
print(x) # [12, 23, 30]
3. 元组在没有歧义的情况下,()可以省略
t1 = (10, 20, 30)
print(t1)
t2 = 10, 20, 30
print(t2, type(t2)) # (10, 20, 30) <class 'tuple'>
1.什么是字典(dict)
1)字典是容器型数据类型(序列); 将{}作为容器的标志,里面多个键值对用逗号隔开(一个键值对就是一个元素):{键1:值1, 键2:值2,…}
2)字典是可变的(支持增删改);字典无序(不支持下标操作)
3)元素的要求 - 元素是键值对
键的要求:只有不可变类型的数据可以作为键,一般使用字符串(做到见名知义);键唯一
值的要求:没有要求
空字典
d1 = {}
print(d1, type(d1)) # {} <class 'dict'>
字典无序
键必须是不可变的数据
键是唯一的
1. 查 - 获取值
1)查单个
字典[键] - 获取指定键对应的值,键不存报错!
字典.get(键) - 获取指定键对应的值,键不存在返回None
字典.get(键, 默认值) - 获取指定键对应的值,键不存在返回指定默认值
students = [
{'name': 'stu1', 'age': 34, 'gender': '男', 'tel': '110', 'score': 89},
{'name': 'stu2', 'age': 20, 'gender': '女', 'tel': '110', 'score': 70},
{'name': 'stu3', 'age': 19, 'gender': '男', 'tel': '110'},
{'name': 'stu4', 'age': 22, 'gender': '男', 'tel': '110', 'score': 25}
]
count = 0
sum1 = 0
for x in students:
# 确定键一定存在用[]语法获取
if x['gender'] == '女':
count += 1
# 键可能存在可能不存在使用get方法获取
sum1 += x.get('score', 0)
print('女生人数:', count, '总分:', sum1)
2)遍历(了解)
“”"
for 键 in 字典:
pass
“”"
stu = {'name': '小明', 'age': 20, 'gender': '男', 'tel': '110'}
for x in stu:
print('x:', x, stu[x])
2. 增、改
字典[键] = 值 - 如果键存在就修改指定键对应的值;如果键不存在就添加键值对
字典.setdefault(键, 值) - 添加键值对(只添加不修改)
键存在就修改
stu['name'] = '小花'
print(stu) # {'name': '小花', 'age': 20, 'gender': '男', 'tel': '110'}
键不存在就添加
orders = [
{'goods_name': '泡面', 'price': 3.5, 'discount': 0.9, 'count': 3},
{'goods_name': '矿泉水', 'price': 1, 'count': 5},
{'goods_name': '火腿肠', 'price': 2.5, 'count': 2},
{'goods_name': '卤蛋', 'price': 2, 'count': 4, 'discount': 0.85}
]
for x in orders:
x.setdefault('discount', 1) # 添加默认值,有discou不变原来的值
print(orders)
3. 删 - 删除键值对
- del 字典[键] - 删除指定键对应的键值对
- 字典.pop(键) - 取出指定键对应的值
stu = {'name': '小明', 'age': 20, 'gender': '男', 'tel': '110'}
del stu['gender']
print(stu) # {'name': '小明', 'age': 20, 'tel': '110'}
result = stu.pop('tel')
print(stu, result) # {'name': '小明', 'age': 20} 110
练习
class1 = {
'name': 'Python2107',
'address': '18教',
'lecturer': [
{'name': '余婷', 'qq': '726550822', 'age': 18},
{'name': '骆昊', 'qq': '67273', 'age': 38}
],
'students': [
{'name': 'stu1', 'tel': '101922', 'gender': '男', 'age': 20, 'linkman': {'name': '张三', 'tel': '120'}},
{'name': 'stu2', 'tel': '1012911', 'gender': '女', 'age': 19, 'linkman': {'name': '李四', 'tel': '119'}},
{'name': 'stu3', 'tel': '0192342', 'gender': '女', 'age': 30, 'linkman': {'name': 'Bob', 'tel': '100'}},
{'name': 'stu4', 'tel': '1101823', 'gender': '男', 'age': 29, 'linkman': {'name': '王五', 'tel': '110'}},
{'name': 'stu5', 'tel': '102323', 'gender': '男', 'age': 23, 'linkman': {'name': '老王', 'tel': '1203'}},
{'name': 'stu6', 'tel': '192389123', 'gender': '女', 'age': 20, 'linkman': {'name': '小明', 'tel': '130'}},
{'name': 'stu7', 'tel': '099121234', 'gender': '男', 'age': 25, 'linkman': {'name': '小花', 'tel': '11923'}}
]
}
# 练习:
# 1) 班级名称
print('班级名称 : ', class1['name'])
dict1 = class1['lecturer']
# 2)获取第一个讲师的姓名
print('第一个讲师的姓名:', dict1[0]['name'])
# 3)获取所有讲师的qq
for x in dict1:
print(x['qq'])
# 4)获取所有学生的姓名
# 5)统计学生女生的个数
dict2 = class1['students']
count = 0
for i in dict2:
if i['gender'] == '女':
count += 1
print(i['name'])
print('学生女生的个数:', count)
# 6)获取所有尾号是0的联系人的姓名
for j in class1['students']:
linkman = j['linkman']
if int(linkman['tel']) % 10 == 0:
print(linkman['name'])
1. 运算符
相对列表,字典不支持: +、*、比较大小
2.相关函数
dict(数据) - 将数据转换成字典
数据的要求:
- 这个数据必须是一个序列
- 序列中元素必须是有且只有两个元素的小序列, 两个元素中第一个元素是不可变的数据
x = ['ab', range(2), (23, 35)]
print(dict(x))
3. 相关方法
- 字典.clear() - 清空字典
- 字典.copy() - 赋值字典产生一个一模一样的新字典(地址不同)
字典.values() - 获取字典所有的值,返回一个新的序列
字典.keys() - 获取字典所有的键,返回一个新的序列
字典.items() - 获取所有的键和值,每一个键值对对应一个元组,返回一个新的序列
c = {'a': 'b', 0: 1, 23: 35}
print(c.values())
print(c.keys())
print(c.items())
for key, value in c.items():
print(key, value)
# 练习:使用列表推导式交换字典的键和值
dict1 = {10: 20, 'a': 'b', 'c': 30}
# {20: 10, 'b': 'a', 30: 'c'}
new_dict1 = {value: key for key, value in dict1.items()}
print(new_dict1)
字典推导
{表达式1:表达式2 for 变量 in 序列}
{表达式1:表达式2 for 变量 in 序列 if 条件语句}
result = {x: x*2 for x in range(5) if x % 2}
print(result) # {1:2, 3:6}
4) 字典1.update(字典2) - 将字典2中所有的键值对都添加到字典1
d1 = {'a': 10, 'b': 20, 'c': 11}
d2 = {'c': 30, 'd': 40}
d1.update(d2)
print(d1) # {'a': 10, 'b': 20, 'c': 30, 'd': 40}
作业
- 定义一个变量保存一个学生的信息,学生信心中包括:姓名、年龄、成绩(单科)、电话、性别
student = {'姓名': '小李', '年龄': 17, '成绩(单科)': 96, 'tel': '18726378972', 'gender': '男'}
print(student)
- 定义一个列表,在列表中保存6个学生的信息(学生信息中包括: 姓名、年龄、成绩(单科)、电话、性别(男、女、不明) )
message = [
{'姓名': '佐助', '年龄': 19, '成绩(单科)': 86, 'tel': '18726378978', 'gender': '男'},
{'姓名': '小樱', '年龄': 15, '成绩(单科)': 66, 'tel': '18726378990', 'gender': '女'},
{'姓名': '小李', '年龄': 17, '成绩(单科)': 23, 'tel': '18726378972', 'gender': '男'},
{'姓名': '井野', '年龄': 14, '成绩(单科)': 54, 'tel': '18726378976', 'gender': '女'},
{'姓名': '白', '年龄': 23, '成绩(单科)': 95, 'tel': '18726378989', 'gender': '不明'},
{'姓名': '卡卡西', '年龄': 27, '成绩(单科)': 99, 'tel': '18726378908', 'gender': '男'},
]
- 统计不及格学生的个数
count = 0
for x in message:
if x['成绩(单科)'] < 60:
count += 1
print('不及格学生的个数:', count)
- 打印不及格未成年学生的名字和对应的成绩
for x in message:
if x['成绩(单科)'] < 60 and x['年龄'] < 18:
print('不及格未成年学生的名字:', x['姓名'], '成绩:', x['成绩(单科)'])
- 求所有男生的平均年龄
sum1 = 0
count = 0
for x in message:
if x['gender'] == '男':
count += 1
sum1 += x['年龄']
print(sum1 / count)
- 打印手机尾号是8的学生的名字
for x in message:
if x['tel'][-1] == '8':
print(x['姓名'])
- 打印最高分和对应的学生的名字
max_score = 0
for x in message:
stu_score = x['成绩(单科)']
if stu_score > max_score:
max_score = stu_score
for x in message:
if x['成绩(单科)'] == max_score:
print('最高分:', max_score, '姓名:', x['姓名'])
- 删除性别不明的所有学生
for x in message:
if x['gender'] == '不明':
message.remove(x)
print(message)
- 将列表按学生成绩从大到小排序(挣扎一下,不行就放弃)
score = []
new_message = []
for x in message:
score.append(x['成绩(单科)'])
new_score = sorted(score, reverse=True)
for i in new_score:
for j in message:
if i == j['成绩(单科)']:
new_message.append(j)
print(new_message)
- 定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)
class_message = {
'class_name': 'python',
'class_location': '成都',
'class_teacher': {'name': 'li', 'gender': '女', 'age': 19},
'lecturer': {'name': 'yu', 'gender': '女', 'age': 18},
'students': [
{'name': 'stu1', 'tel': '101922', 'gender': '男', 'age': 20, 'linkman': {'name': '张三', 'tel': '120'}},
{'name': 'stu2', 'tel': '1012911', 'gender': '女', 'age': 19, 'linkman': {'name': '李四', 'tel': '119'}},
{'name': 'stu3', 'tel': '0192342', 'gender': '女', 'age': 30, 'linkman': {'name': 'Bob', 'tel': '100'}}]
}
-
已知一个列表保存了多个狗对应的字典:
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': '母'} ]
-
利用列表推导式获取所有狗的品种
[‘银狐’, ‘法斗’, ‘土狗’, ‘哈士奇’, ‘银狐’, ‘土狗’]
-
breeds = []
for x in dogs:
breeds.append(x['breed'])
print(breeds)
-
利用列表推导式获取所有白色狗的名字
[‘贝贝’, ‘可乐’]
name_white = []
for x in dogs:
if x['color'] == '白色':
name_white.append(x['name'])
print(name_white)
- 给dogs中没有性别的狗添加性别为 ‘公’
for x in dogs:
x.setdefault('gender', '公')
print(dogs)
- 统计 ‘银狐’ 的数量
count = 0
for x in dogs:
if x['breed'] == '银狐':
count += 1
print('银狐的数量:', count)