列表进阶
列表相关函数
列表的比较运算
==、!=、>、<、>=、<=
-
==、!=
print(10 == 'abc') # False print([10, 20, 30] == [10, 20, 30]) # True print([10, 20, 30] == [10, 30, 20]) # False print([10, 20] == 'abc') # False
-
<、>、>=、<=
注意:列表比较大小,只能是两个列表进行比较
比较原则:比较第一对不相等的元素的大小(相同位置的元素是一对儿)print([10,2000,30000,33256] > [100,1]) # False print([10,20,30] > [10,2,300]) # True # print([10,'abc',20,30] > [10,2,300]) # TypeError: '>' not supported between instances of 'str' and 'int'
列表(序列)相关函数
-
sum
sum(列表) - 求列表中所有元素的数值和(列表中元素必须是数字)
scores = [100, 19, 34, 89, 67, 34, 99] print(sum(scores)) # 442 print(sum(range(1, 101))) # 5050
-
max、min
max(列表) - 获取列表中的最大元素(列表中的元素支持比较运算)
min(列表) - 获取列表中的最小元素(列表中的元素支持比较运算)
scores = [100, 19, 34, 89, 67, 34, 99] print(max(scores)) # 100 print(min(scores)) # 19
-
sorted
sorted(列表) - 将列表中的元素从小到大排序,产生一个新的列表
sorted(列表, reverse=True) - 将列表中的元素从大到小排序,产生一个新的列表scores = [100, 19, 34, 89, 67, 34, 99] new_scores = sorted(scores, reverse=True) print(scores) # [100, 19, 34, 89, 67, 34, 99] print(new_scores) # [100, 99, 89, 67, 34, 34, 19]
-
len
len(列表) - 统计列表中元素的个数
-
list
list(序列) - 将指定序列转换成列表
任何序列都可以转换成列表,转换的时候直接将序列中的元素作为列表的元素print(list('abc')) # ['a', 'b', 'c'] print(list(range(10, 15))) # [10, 11, 12, 13, 14]
列表相关方法
方法的使用套路:列表.xxx()
-
clear
列表.clear() - 清空列表
nums = [20, 89, 23] print(nums) # [20, 89, 23] nums.clear() print(nums) # []
-
copy
列表.copy() - 拷贝(浅拷贝)原列表产生一个一模一样的新列表,将新列表返回
用变量保存数据的时候,变量真正保存的其实是数据在内存中的地址;
当用一个变量直接给另外一个变量赋值的时候,赋的其实是变量中保存地址,赋值后两个变量指向的是同一块内存。a = [20, 89, 23] b = a c = a.copy() # 列表[:]、列表*1、列表+[] 都是浅拷贝 print('a:', a) # a: [20, 89, 23] print('b:', b) # b: [20, 89, 23] print('c:', c) # c: [20, 89, 23] a.append(100) print('a:', a) # a: [20, 89, 23, 100] print('b:', b) # b: [20, 89, 23, 100] print('c:', c) # c: [20, 89, 23]
-
count
列表.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
列表.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
列表.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
列表.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() - 将列表中的元素升序排序(直接修改原列表元素的顺序,不会产生新的列表)
列表.sort(reverse=True) - 降序排列sorted(序列) - 将序列中的元素升序排序(不会修改原序列中元素的顺序,会产生一个新的列表)
sorted(序列, reverse=True) - 降序排列nums = [10, 34, 45, 90, 10, 45, 45, 78, 45] nums.sort() print(nums) # [10, 10, 34, 45, 45, 45, 45, 78, 90] nums = [10, 34, 45, 90, 10, 45, 45, 78, 45] new_nums = sorted(nums) print(new_nums) # [10, 10, 34, 45, 45, 45, 45, 78, 90]
列表推导式
列表推导式:一种创建列表的表达式
-
结构1
结构:[表达式 for 变量 in 序列]
原理:让变量去序列中取值,一个一个的取,每取一个值就计算一次表达式的结果,并且将计算的结果作为列表的元素
list1 = [10 for x in range(5)] print(list1) # [10, 10, 10, 10, 10] list2 = [x + 2 for x in range(5)] print(list2) # [2, 3, 4, 5, 6]
应用:基于原序列中的元素得到新的序列(对原序列中元素进行统一变换得到新元素)
练习1:提取nums中所有元素的个位数
nums = [18,29,892,78,91,56] result = [i % 10 for i in nums] print(result)
练习2:使用列表推导式让所有员工的薪资提高10%
pays = [18290,10000,8921,7828,12000,5600] result = [i*1.1 for i in pays] print(result)
-
结构2
结构:[表达式 for 变量 in 序列 if 条件语句]
原理:让变量去序列中取值,一个一个取,取完为止,每取一个值就判断一次条件语句是否成立,如果成立就计算一次表达式的结果,并且将结果作为列表的元素
list1 = [x for x in range(5,15) if x % 2] print(list1) # [5,7,9,11,13]
应用:数据筛选
案例1:获取nums中所有的偶数
nums = [18, 90, 43, 67, 88, 19, 84] result = [i for i in nums if i % 2 == 0] print(result) # [18, 90, 88, 84]
案例2:获取列表中所有数字,并且将数字都乘以10
list1 = [10, 2.25, 'abc', False, True, 'as12', 4, 2.5] result = [i * 10 for i in list1 if type(i) in [int,float]] print(result) # [100, 22.5, 40, 25.0]