其他分享
首页 > 其他分享> > Day007 - 元组与字典

Day007 - 元组与字典

作者:互联网

列表相关函数

max、min

sum

sort与sorted

len

list

列表推导式

语法

拓展 - 三目运算符

C/Java语言的三目运算符

Python的三目运算符

表达式1 if 条件语句 else 表达式2

应用

元组

空元组

t1 = ()
print(type(t1), len(t1))

只有一个元素的元组

list1 = [12]
print(list1, type(list1), len(list1))  # [12] <class 'list'> 1
t2 = (12)  # 不加逗号括号表示将元素括起来,而不是表示为元组
print(t2, type(t2))  # 12 <class 'int'>
t3 = (12,)
print(t3, type(t3))  # (12,) <class 'tuple'>

普通情况

t4 = (10, 'df', True)
print(t4)  # (10, 'df', True)

元组的查询

列表获取元素的方式

通过变量直接获取元组的元素

命名元组

可变参数

元组不可变

字典

作用

定义

空字典{}

d1 = {}
print(type(d1), len(d1), bool(d1))  # <class 'dict'> 0 False

键是不可变数据

d2 = {1: 10, 'a': 20, (10, 20): 30}  # {1: 10, 'a': 20, (10, 20): 30}
print(d2)
# d3 = {1: 10, 'a': 20, [10, 20]: 30}  # TypeError: unhashable type: 'list'

键是唯一的

d4 = {1: 10, 'a': 20, (10, 20): 30, 'a': 30}  # 如果有重复键那么只会保存一个键的值
print(d4)  # {1: 10, 'a': 30, (10, 20): 30}

字典是无序的

print({'a': 10, 'b': 20} == {'b': 20, 'a': 10})  # True
print([('a', 10), ('b', 20)] == [('b', 20), ('a', 10)])  # False

字典的增删改查

字典的查询

获取单个值

字典的遍历

实际应用中的字典和列表

定义一个保存一个班级信息

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', 'linkman': {'name': '张三', 'tel': '923'}},
        {'name': 'stu2', 'school': '攀枝花学院', 'tel': '8999', 'linkman': {'name': '李四', 'tel': '902'}},
        {'name': 'stu3', 'school': '成都理工大学', 'tel': '678', 'linkman': {'name': '小明', 'tel': '1123'}},
        {'name': 'stu4', 'school': '四川大学', 'tel': '9900', 'linkman': {'name': '小花', 'tel': '782'}},
        {'name': 'stu5', 'school': '西南交大', 'tel': '665', 'linkman': {'name': '老王', 'tel': '009'}}
    ]}
  1. 获取班级名称

    class_name = class1['name']
    print(class_name)
    
  2. 获取讲师QQ

    lecturer_QQ = class1['lecturer']['QQ']
    print(lecturer_QQ)
    
  3. 获取所有学生的名字和学校

    for stu in class1['students']:
        print(stu['name'], stu['school'])
    
  4. 获取所有学生的联系人的电话

    for stu in class1['students']:
        print(stu['linkman']['tel'])
    

课后作业

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]
new_nums = []
for index1 in nums:
    if not new_nums.count(index1) :
        new_nums.append(index1)
new_nums.sort(reverse=True)
print(new_nums)
# [282, 234, 197, 177, 107, 91, 88, 70]

2.利用列表推导式, 完成以下需求

a. 生成一个存放1-100中各位数为3的数据列表

结果为 [3, 13, 23, 33, 43, 53, 63, 73, 83, 93]
print([num for num in range(3,100) if num % 10 == 3])

b. 利用列表推到是将 列表中的整数提取出来

例如:[True, 17, "hello", "bye", 98, 34, 21] --- [17, 98, 34, 21]
eg = [True, 17, "hello", "bye", 98, 34, 21]
b = [item for item in eg if type(item) == int]
print(b)

c.利用列表推导式 存放指定列表中字符串的长度

例如 ["good", "nice", "see you", "bye"] --- [4, 4, 7, 3]
str1 = ["good", "nice", "see you", "bye"]
c = [len(item) for item in str1]
print(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)获取所有学生的姓名和分数

print([(stu['name'], stu['score']) for stu in class1['students']])

4)获取所有学生联系人的名字和电话

print([(stu['linkman']['name'], stu['linkman']['tel']) for stu in class1['students']])

5)获取班级最高分

print('最高分为:', max([stu['score'] for stu in class1['students']]))
# 最高分为: 98

6)获取班级分数最高的学生的姓名

print('分数最高的学生姓名为:', [stu['name'] for stu in class1['students']
                      if stu['score'] == max([stu['score'] for stu in class1['students']])])
# 分数最高的学生姓名为: ['stu1']

7)计算班级学生的平均分

print('平均分为:', sum([stu['score'] for stu in class1['students']]) / len(class1['students']))
# 平均分为: 70.33333333333333

8)统计班级中未成年人数

print('未成年人数为:', len([stu['name'] for stu in class1['students'] if stu['age'] < 18]))
# 未成年人数为: 2

9)用字典统计每个学校的人数, 类似: {'清华大学': 1, '攀枝花学院': 3}

# 方法1:
nums = {}
for stu in class1['students']:
    if stu['school'] not in nums:
        nums[stu['school']] = nums.get(stu['school'], 1)
        # nums.setdefault(stu['school'], 1) # 方法2
    else:
        nums[stu['school']] += 1
print(nums)

# 改进:
nums = {}
for stu in class1['students']:
    nums[stu['school']] = nums.get(stu['school'], 0) + 1
    # nums[stu['school']] = nums.setdefault(stu['school'], 0) + 1
print(nums)

# {'清华大学': 1, '攀枝花学院': 3, '成都理工大学': 2, '四川大学': 2, '西南交大': 1}

标签:10,tel,name,nums,元组,stu,print,Day007,字典
来源: https://blog.csdn.net/qq_20814305/article/details/118947283