什么是元组(tuple)
只有一个元素的元组 - 唯一的元素后面必须加逗号
list1 = [12]
print(list1, type(list1), len(list1)) # [12] 1
t2 = (12)
print(t2, type(t2)) # 12
t3 = (12,)
print(t3, type(t3)) # (12,)
在没有歧义的情况下,元素的小括号可以省略
t5 = 10, 65, 54
元组是不可变列表 - 列表中不可变相关操作元组都支持
查 - 获取元素
point = (10, 23, 12)
x, y, z = point
print(x, y, z)
info = ('张三', 18, 175, 180, 90, 67, 89)
name, age, *other = info
print(name, age) # 张三 18
print(other) # [175, 180, 90, 67, 89]
name, *other, math = info
print(name, math, other) # 张三 89 [18, 175, 180, 90, 67]
什么是字典(dict)
空字典:{}
键是不可变的数据
键是唯一的
d4 = {'a': 10, 'b': 20, 'c': 30, 'b': 40}
print(d4) # {'a': 10, 'b': 40, 'c': 30} - 20 被覆盖
字典是无序的
print({'a': 10, 'b': 20} == {'b': 20, 'a': 10}) # True
字典的增删改查
1.创建一个列表,列表中有10个数字, 保证列表中元素的顺序,对列表进行排重,并对列表使用进行降序排序
例如:随机生成了[70, 88, 91, 70, 107, 234, 91, 177, 282, 197]
--- 去重之后 [70, 88, 91, 107, 234, 177, 282, 197]
---- 降序排序 [282, 234, 197, 177, 107, 91, 88, 70]
nums = [70, 88, 91, 70, 107, 234, 91, 177, 282, 197]
for num in nums[::-1]:
if nums.count(num) > 1:
nums.remove(num)
nums.sort(reverse=True)
print(nums)
2.利用列表推导式, 完成以下需求
a. 生成一个存放1-100中各位数为3的数据列表
结果为 [3, 13, 23, 33, 43, 53, 63, 73, 83, 93]
list_a = [x for x in range(1, 100) if x % 10 == 3]
print(list_a)
b. 利用列表推到是将 列表中的整数提取出来
例如:[True, 17, "hello", "bye", 98, 34, 21] --- [17, 98, 34, 21]
list_1 = [True, 17, "hello", "bye", 98, 34, 21]
list_b = [item for item in list_1 if type(item) == int]
print(list_b)
c.利用列表推导式 存放指定列表中字符串的长度
例如 ["good", "nice", "see you", "bye"] --- [4, 4, 7, 3]
list_2 = ["good", "nice", "see you", "bye"]
list_c = [len(item) for item in list_2]
print(list_c)
4.已经一个班级字典如下:
class1 = {
'name': 'python2104',
'address': '23教',
'lecturer': {'name': '余婷', 'age': 18, 'QQ': '726550822'},
'leader': {'name': '舒玲', 'age': 18, 'QQ': '2343844', 'tel': '110'},
'students': [
{'name': 'stu1', 'school': '清华大学', 'tel': '1123', 'age': 18, 'score': 98, 'linkman': {'name': '张三', 'tel': '923'}},
{'name': 'stu2', 'school': '攀枝花学院', 'tel': '8999', 'age': 28, 'score': 76, 'linkman': {'name': '李四', 'tel': '902'}},
{'name': 'stu3', 'school': '成都理工大学', 'tel': '678', 'age': 20, 'score': 53, 'linkman': {'name': '小明', 'tel': '1123'}},
{'name': 'stu4', 'school': '四川大学', 'tel': '9900', 'age': 30, 'score': 87, 'linkman': {'name': '小花', 'tel': '782'}},
{'name': 'stu5', 'school': '西南交大', 'tel': '665', 'age': 22, 'score': 71, 'linkman': {'name': '老王', 'tel': '009'}},
{'name': 'stu6', 'school': '成都理工大学', 'tel': '892', 'age': 32, 'score': 80, 'linkman': {'name': '老王2', 'tel': '0091'}},
{'name': 'stu7', 'school': '四川大学', 'tel': '431', 'age': 17, 'score': 65, 'linkman': {'name': '老王3', 'tel': '0092'}},
{'name': 'stu8', 'school': '攀枝花学院', 'tel': '2333', 'age': 16, 'score': 32, 'linkman': {'name': '老王4', 'tel': '0093'}},
{'name': 'stu9', 'school': '攀枝花学院', 'tel': '565', 'age': 21, 'score': 71, 'linkman': {'name': '老王5', 'tel': '0094'}}
]
}
1)获取班级位置
print(class1['address'])
2)获取班主任的名字和电话
print(class1['leader']['name'], class1['leader']['tel'])
3)获取所有学生的姓名和分数
for stu in class1['students']:
print(stu['name'], stu['score'])
4)获取所有学生联系人的名字和电话
for stu in class1['students']:
print(stu['linkman']['name'], stu['linkman']['tel'])
5)获取班级最高分
max_score = 0
for stu in class1['students']:
if stu['score'] > max_score:
max_score = stu['score']
print(max_score)
6)获取班级分数最高的学生的姓名
max_score = 0
name = ''
for stu in class1['students']:
if stu['score'] > max_score:
name = stu['name']
max_score = stu['score']
print(name)
7)计算班级学生的平均分
score_sum = 0
count = 0
for stu in class1['students']:
score_sum += stu['score']
count += 1
print(score_sum/count)
8)统计班级中未成年人数
count = 0
for stu in class1['students']:
if stu['age'] < 18:
count += 1
print(count)
9)用字典统计每个学校的人数, 类似: {'清华大学': 1, '攀枝花学院': 3}
dict_ = {}
for stu in class1['students']:
if stu['school'] in dict_:
dict_[stu['school']] += 1
else:
dict_[stu['school']] = 1
print(dict_)