day7学习总结:
1. 列表比较运算:
- 注意1:两个列表相等,元素的个数,顺序必须是一样的
print([10, 20, 30] == [10, 20, 30]) # True
- 注意2:只能是两个列表进行比较
print([10, 20] == 'abc') # False
- 注意3:比较的是第一对不相等的元素的大小(相同位置的元素是一对)。
print([10, 2000, 30992, 42220, 522340] > [100, 1]) # False
print([10, 20, 30] > [10, 2, 300]) # True
2. 列表相关函数:
- sum(列表):求列表中所有元素的数值和(列表中元素必须是数字)
scores = [100, 19, 34, 89, 67, 34, 99]
print(sum(scores)) # 442
print(sum(range(1, 101))) # 5050
- max(列表),min(列表):获取列表中的最大(最小)元素(列表中的元素支持比较运算)
scores = [100, 19, 34, 89, 67, 34, 99]
print(max(scores))
print(min(scores))
- sorted(列表):将列表中的元素从小到大排序,产生一个新的列表
- sorted(列表, reverse=True):将列表中的元素从大到小排序,产生一个新的列表
scores = [100, 19, 34, 89, 67, 34, 99]
new_scores = sorted(scores, reverse=True)
scores1 = sorted(scores)
print(scores1) # [19, 34, 34, 67, 89, 99, 100]
print(new_scores) # [100, 99, 89, 67, 34, 34, 19]
- len(列表)统计列表中元素的个数
- list(序列)将指定序列转换成列表
- 注意:任何序列都可以转换成列表,转换的时候直接将序列中的元素作为列表的元素
print(list('song')) # ['s', 'o', 'n', 'g']
print(list(range(10, 15))) # [10, 11, 12, 13, 14]
3. 列表相关方法:
- 方法的使用套路:列表.xxx()
- 列表.clear() :请空列表
list1 = ['s', 'o', 'n', 'g']
list1.clear()
print(list1) # []
- 列表.copy() : 拷贝(浅拷贝)原列表产生一个一模一样的新列表,将新列表返回
- 列表.count(数据): 统计列表中指定数据出现的次数(数据的个数)
nums = [10, 34, 45, 90, 10, 45, 45, 78, 45]
print(nums.count(10)) # 2
print(nums.count(45)) # 4
print(nums.count(100)) # 0
- 列表.extend(序列):将序列中所有的元素全部添加到列表的最后
nums = [10, 20, 30]
nums.extend('abc')
print(nums) # [10, 20, 30, 'a', 'b', 'c']
nums = [10, 20, 30]
nums.extend([100, 200])
print(nums) # [10, 20, 30, 100, 200]
- 列表.index(数据):获取指定数据在列表中的第一个下标(如果数据不存在会报错)
nums = [10, 34, 45, 90, 10, 45, 45, 78, 45]
print(nums.index(34)) # 1
print(nums.index(45)) # 2
# print(nums.index(100)) # 报错
- 列表.reverse():列表倒序
nums = [10, 34, 45, 90, 10, 45, 45, 78, 45]
nums.reverse()
print(nums) # [45, 78, 45, 45, 10, 90, 45, 34, 10]
- 列表.sort():将列表中的元素升序排序(直接修改原列表元素的顺序,不会产生新的列表
- 列表.sort(reverse=True):将列表中的元素降序排序
- 与sorted(序列)区别:sorted(序列)不会修改原序列中元素的顺序,会产生一个新的列表;列表.sort() 会修改原列表元素的顺序,不会产生新的列表
4. 列表推导式:一种创建列表的表达式
- 结构1:[表达式 for 变量 in 序列]
- 原理:让变量去序列中取值,一个一个的取,每取一个值就计算一次表达式的结果,并且将计算的结果作为列表的元素
- 应用:基于原序列中的元素得到新的序列(对原序列中元素进行统一变换得到新元素)
- 举例1:提取nums中所有元素的个位数
nums = [18, 29, 892, 78, 91, 56]
result = [x % 10 for x in nums]
print(result) # [8, 9, 2, 8, 1, 6]
- 举例2:使用列表推导式让所有员工的薪资提高10%
pays = [18290, 10000, 8921, 7828, 12000, 5600]
result = [x*1.1 for x in pays]
print(result) # [8, 9, 2, 8, 1, 6]
- 结构2:[表达式 for 变量 in 序列 if 条件语句]
- 原理:让变量去序列中取值,一个一个取,取完为止,每取一个值就判断一次条件语句是否成立,如果成立就计算一次表达式的结果,并且将结果作为列表的元素
- 应用:数据筛选
- 举例1:获取nums中所有的偶数
nums = [18, 90, 43, 67, 88, 19, 84]
# [18, 90, 88, 84]
result = [x for x in nums if x % 2 == 0]
print(result) # [18, 90, 88, 84]
- 举例2:获取列表中所有数字,并且将数字都乘以10
list1 = [10, 2.25, 'abc', False, True, 'as12', 4, 2.5]
# result = [x*10 for x in list1 if type(x) == int or type(x) == float]
result = [x*10 for x in list1 if type(x) in [int, float]]
print(result) # [100, 22.5, 40, 25.0]