day7 - 列表和元祖
- 列表相关操作和相关函数
- 列表相关方法
- 列表推导式
- 元祖
一、列表相关操作
1)数学运算符:+、*
列表1+列表2 - 将两个列表合并成为一个新的列表
list1 = [10, 20, 30]
list2 = [100, 200]
result = list1 + list2
print(result) # [10, 20, 30, 100, 200]
列表 * N 、N * 列表 - 将列表中的元素重复N产生一个新的列表
print(list1 * 3) # [10, 20, 30, 10, 20, 30, 10, 20, 30]
2)比较运算:> < >= <= == !=
a.比较相等:== !=
list1 = [10, 20, 30]
print(list1 == [10, 20, 30]) # True
print(list1 == [20, 10, 30]) # False
b.比较大小: > < >= <=
两个列表比较大小,比较的是第一对不相等的元素的大小
list1 = [1, 2, 3]
list2 = [1, 2, 3, -4]
print(list2 > list1) # True
3)in 和 not in
元素 in 列表 - 判断指定列表中是否存在指定元素
元素 not in 列表 - 判断指定列表中是否不存在指定元素
print(10 in [10, 20, 30]) # True
print(100 not in [10, 20, 30]) # True
print([10, 20] in [10, 20, 30]) # False
print([10, 20] in [[10, 20], 30]) # True
-
列表相关函数(系统函数):sum max min len sorted list
1)sum(列表) - 求列表中所有元素的和(列表必须是数字列表)
# 1+2+3+...+100 print(sum(range(1,101)))
2)max(列表)/min(列表) - 求列表中所有元素的最大值/最小值
scores = [18, 90, 67, 8, 82]
print(max(scores))
print(min(scores))
3)sorted(列表) - 将列表中的元素从小到大排序,产生一个新的列表
soretd(列表, reverse=True) - 将列表中的元素从大到小排序,产生一个新的列表
scores = [18, 90, 67, 8, 82]
new_scores = sorted(scores)
print(new_scores) # [8, 18, 67, 82, 90]
scores = [18, 90, 67, 8, 82]
new_scores = sorted(scores, reverse=True)
print(new_scores) # [90, 82, 67, 18, 8]
4)list - 将其他数据转换成列表
list(数据) - 将指定数据转换成列表。(所有的序列都可以转换成列表;将其他序列转换成列表的时候直接将序列的元素作为列表的元素)
result = list('abc')
print(result) # ['a', 'b', 'c']
result = list(range(5))
print(result) # [0, 1, 2, 3, 4]
二、列表相关方法
-
clear
列表.clear() - 清空列表
nums = [10, 89, 23, 5] nums.clear() print(nums) # []
-
copy
列表.copy() - 复制指定列表产生一个一样的新列表,将新的列表返回
nums = [10, 89, 23, 5] nums2 = nums.copy() print(nums2) # [10, 89, 23, 5]
-
count
列表.count(元素) - 统计列表中指定元素的个数
nums = [23, 89, 78, 23, 10, 23, 9, 23, 10] result = nums.count(23) print(result) # 4
-
extend
列表.extend(序列) - 将序列中所有的元素都添加到列表中
list1 = [10, 20, 30] list1.extend([100, 200]) print(list1) # [10, 20, 30, 100, 200]
-
index
列表.index(元素) - 获取元素在列表中对应下标(返回是0开始的那个下标);
如果元素不存在会报错;如果元素有多个,只返回最前面那个元素的下标
list1 = [12, 89, 7, 12, 65, 23, 89] print(list1.index(12)) # 0 print(list1.index(65)) # 3 # print(list1.index(120)) # 报错! ValueError: 120 is not in list print(list1.index(89)) # 1
-
reverse
列表.reverse() - 倒序
list1 = [12, 89, 7, 12, 65, 23, 89] list1.reverse() print(list1) # [89, 23, 65, 12, 7, 89, 12]
-
sort
列表.sort() - 将列表元素从小到大排序
列表.sort(reverse=True) - 将列表元素从大到小排序
sorted(列表) - 将列表元素从小到大排序, 产生一个新的列表
sorted(列表, reverse=True) - 将列表元素从大到小排序, 产生一个新的列表
list1 = [12, 89, 7, 12, 65, 23, 89] list1.sort() print(list1) # [7, 12, 12, 23, 65, 89, 89] list1 = [12, 89, 7, 12, 65, 23, 89] result = sorted(list1) print(list1) # [12, 89, 7, 12, 65, 23, 89] print(result) # [7, 12, 12, 23, 65, 89, 89]
三、列表推导式
-
列表推导式 - 创建列表的表达式,主要用于对元素进行变换和筛选
""" 结构1: [表达式 for 变量 in 序列] 原理:创建一个列表(让变量去序列中取值,一个一个的取,取一个值就计算一次表达式的结果并且将计算结果作为列表的元素) 作用:将原序列中的元素按照指定规则(表达式)进行统一变换得到一个列表 结构2: [表达式 for 变量 in 序列 if 条件语句] 原理:让变量去序列中取值,一个一个的取,去一个值就判断一次条件语句是否成立,如果成立才计算表达式的结果,并且将结果作为列表的元素 作用:提取序列中满足条件的元素 """
四、元祖
-
认识元组(tuple)
是容器;将()作为容器的标志里面多个元素用逗号隔开:(元素1, 元素2, 元素3,…)
不可变的(不支持增删改);有序的
# 空元组 t1 = () # 单个元素的元组(重要!!!!!): 必须在唯一的元素后加逗号 t2 = (20,) print(t2, type(t2), len(t2)) t3 = (19, 20, 34)
-
-
元祖就是不可变的列表
列表中和增删改无关的操作,元组都支持
查:
names = ('奥特曼', '开端', '甄嬛传', '人民的名义', '康熙王朝', '琅琊榜', '庆余年') print(names[1], names[-1]) print(names[1:-1:-1]) # () print(names[1:-1:2]) # ('开端', '人民的名义', '琅琊榜') print(names[2:]) # ('甄嬛传', '人民的名义', '康熙王朝', '琅琊榜', '庆余年') for x in names: print(x) for index in range(len(names)): print(index, names[index]) for index,item in enumerate(names): print(index, item)
相关操作:
print((10, 20) + (100, 200)) # (10, 20, 100, 200) print((10, 20) * 3) # (10, 20, 10, 20, 10, 20) print((10, 20) == (20, 10)) # False print(10 in (10, 20, 30)) # True
相关函数: sum、max、min、len、sorted
部分相关方法:count、index
-
元祖不只是不可变的元素
# 1) 单个元素的元组: (元素,) # 2) 在没有歧义的情况下,元组的()可以省略 t1 = (10, 20, 30) t2 = 10, 20, 30 print(t1, t2) # (10, 20, 30) (10, 20, 30) # 3) 获取元素的时候,可以让变量的个数和元组中元素个数一致 (了解) t1 = (10, 20, 30) x, y, z = t1 print(x, y, z) # 10 20 30 a, b, c = 10, 20, 30 # a, b, c = (10, 20, 30) names = ('奥特曼', '开端', '甄嬛传', '人民的名义', '康熙王朝', '琅琊榜', '庆余年') x, *y = names print(x, y) # 奥特曼, ['开端', '甄嬛传', '人民的名义', '康熙王朝', '琅琊榜', '庆余年'] *x, y = names print(y, x) # 庆余年 ['奥特曼', '开端', '甄嬛传', '人民的名义', '康熙王朝', '琅琊榜'] x, *y, z = names print(x, z, y) # 奥特曼 庆余年 ['开端', '甄嬛传', '人民的名义', '康熙王朝', '琅琊榜'] x, y, *z = names print(x, y, z) # 奥特曼 开端 ['甄嬛传', '人民的名义', '康熙王朝', '琅琊榜', '庆余年']
作业
- 创建一个列表,列表中有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 x in nums:
if x not in new_nums:
new_nums.append(x)
i = new_nums
i.sort(reverse=True)
print(i)
- 利用列表推导式, 完成以下需求
a. 生成一个存放1-100中各位数为3的数据列表
结果为 [3, 13, 23, 33, 43, 53, 63, 73, 83, 93]
num = [1,2,3,4,5...,99,100 ]
result = [x for x in num if x % 10 == 3]
print(result)
b. 利用列表推到是将 列表中的整数提取出来
例如:[True, 17, "hello", "bye", 98, 34, 21] --- [17, 98, 34, 21]
num = [True, 17, "hello", "bye", 98, 34, 21]
result = [x for x in num if type(x) == int]
print(result)
c.利用列表推导式 存放指定列表中字符串的长度
例如: ["good", "nice", "see you", "bye"] --- [4, 4, 7, 3]
num = ["good", "nice", "see you", "bye"]
new_num = [len(i) for i in num]
print(new_num)
d. 利用列表推导式删除列表中整数个位数小于5的元素
例如:[24, 'abc', 99, True, 21, 38, 'hello'] --- ['abc', 99, True, 38, 'hello']
num = [24, 'abc', 99, True, 21, 38, 'hello']
new_num = [x for x in num if type(x) != int or x % 10 > 5]
print(new_num)
e. 利用列表推导式获取元素是元组的列表中每个元组的最后一个元素
例如:[(10, 20, 30), ('abc', 'hello'), (1, 2, 3.4), (True, False)] --- [30, 'hello', 3.4, False]
num = [(10, 20, 30), ('abc', 'hello'), (1, 2, 3.4), (True, False)]
result = [x[-1] for x in num]
print(result)
f.利用列表推导式将数字列表中所有的奇数乘以2,所有的偶数除以2
例如: [23, 4, 67, 88, 90, 21] -> [46, 2, 134, 44, 45, 42]
-
已知一个列表获取列表中指定元素所有的下标
例如:[10, 20, 34, 10, 9, 78] 10的下标:[0, 3] 20的下标:[1] 30的下标:[]
-
*已知一个数字列表,写程序判断这个列表时候是连续递增列表。
例如: [1, 2, 3, 4, 5] -> True [23, 45, 78, 90] -> True [1, 3, 2, 4, 5] -> False
-
已知两个列表,将两个列表按照下面的规律交叉合并
A = [10, 20, 30, 40, 50] B = [100, 200, 300] 结果:[10, 100, 20, 200, 30, 300, 40, 50]
-
已知两个有序列表,将两个列表合并,合并后的新列表中元素仍然是递增列表
A = [10, 20, 30, 40, 50] B = [25, 44, 60] 结果:[10, 20, 25, 30, 40, 45, 50, 60]