一、列表
1.1 列表的介绍
列表是能装对象的对象,有顺序的(按照我们添加的顺序保存)。
在代码中使用[ ]表示列表,列表可以放任意的数据,每一项数据与数据之间用逗号隔开
1.2 列表的索引和切片
列表同样也拥有索引和切片:
1 lst = ["麻花藤", "王剑林", "马芸", "周鸿医", "向华强"] 2 print(lst[0]) #获取第一个元素 3 print(lst[1]) 4 print(lst[2]) 5 6 lst[3] = "流动强" 7 print(lst) #["麻花藤", "王剑林", "马芸", "流动强", "周鸿医", "向华强"] 8 9 s0 = "向华强" 10 s0[1] = "美" # TypeError: 'str' object does not support item assignment 不允许改变 11 print(s0)
列表的切片:
1 lst = ["麻花藤", "王剑林", "马芸", "周鸿医", "向华强"] 2 print(lst[0:3]) # ['麻花藤', '王剑林', '马芸'] 3 print(lst[:3]) # ['麻花藤', '王剑林', '马芸'] 4 print(lst[1::2]) # ['王剑林', '周鸿医'] 也有步长 5 print(lst[2::-1]) # ['马芸', '王剑林', '麻花藤'] 也可以倒着取 6 print(lst[-1:-3:-2]) # 倒着带步长
1.3 列表的增删改查
list和str是不一样的,list可以发生改变,所以直接就在原来的对象上进行了操作
1.增
1 lst = ["西游记", "红楼梦", "水浒传"] 2 print(lst) 3 lst.append("三国演义") 4 print(lst) #['西游记', '红楼梦', '水浒传', '三国演义'] 5 6 #插入 7 lst = ["西游记", "红楼梦", "水浒传"] 8 lst.insert(1, "三国演义") 9 print(lst) #['西游记', '红楼梦', '水浒传', '三国演义'] 10 11 #迭代添加 12 lst = ["西游记", "水浒传"] 13 lst.extend(["三国演义", "红楼梦"]) 14 print(lst) #['西游记', '水浒传', '三国演义', '红楼梦']
2. 删
1 lst = ["西游记", "红楼梦", "水浒传", "三国演义", "斗破苍穹"] 2 print(lst) 3 deleted = lst.pop() 4 print("被删除的", deleted) #被删除的 斗破苍穹 5 print(lst) #['西游记', '红楼梦', '水浒传', '三国演义'] 6 7 el = lst.pop(2) 8 print(el) #水浒传 9 print(lst) #['西游记', '红楼梦', '三国演义'] 10 11 lst.remove("西游记") 12 print(lst) #['红楼梦', '三国演义'] 13 # lst.remove("哈哈") # 删除不存在的元素会报错 14 # # print(lst) 15 16 lst.clear() #清空list 17 print(lst) #[] 18 19 #切片删除 20 lst = ["西游记", "红楼梦", "水浒传", "三国演义", "斗破苍穹"] 21 del lst[1:3] 22 print(lst) #['西游记', '三国演义', '斗破苍穹']
3. 改
索引切片修改
# 修改 lst = ["太白", "太黑", "五色", "银王", "⽇天"] lst[1] = "太污" # 把1号元素修改成太污 print(lst) lst[1:4:3] = ["麻花藤", "哇靠"] # 切片修改也OK. 如果步⻓不是1, 要注意. 元素的个 数 print(lst) lst[1:4] = ["李嘉诚个有钱人"] # 如果切片没有步长或者步长是1. 则不用关心这个数 print(lst)
4. 查
列表是一个可迭代对象。所以可以进行for循环
1 for el in lst: 2 print(el)
1 for i in range(len(lst)): 2 print(lst[i])
1.4 列表的常用功能
1 lst = ["太白", "太黑", "五色", "银王", "日天", "太白"] 2 c = lst.count("太白") #查询太白出现的次数 3 print(c) # 2 4 5 lst = [1, 5, 88, 9, 87, 0] 6 lst.sort() #排序 , 默认升序 7 print(lst) #[0, 1, 5, 9, 87, 88] 8 lst.sort(reverse=True) #降序 9 print(lst) #[88, 87, 9, 5, 1, 0] 10 11 lst = ["太白", "太黑", "五色", "银王", "日天", "太白"] 12 print(lst) 13 lst.reverse() #反转 14 print(lst) #['太白', '日天', '银王', '五色', '太黑', '太白'] 15 16 l = len(lst) # 列表的长度 17 print(l)
1.5 列表的嵌套
采用降维操作,一层一层的看就好
1 lst = [1, "太白", "wusir", ["马虎疼", ["可口可乐"], "王剑林"]] 2 # 找到wusir 3 print(lst[2]) 4 5 # 找到太白和wusir 6 print(lst[1:3]) 7 8 # 找到太白的白字 9 print(lst[1][1]) 10 11 # 将wusir拿到. 然后首字母大写. 再扔回去 12 s = lst[2] 13 s = s.capitalize() 14 lst[2] = s 15 print(lst) 16 17 # 简写 18 lst[2] = lst[2].capitalize() 19 print(lst) 20 21 # 把太白换成太黑 22 lst[1] = lst[1].replace("白", "黑") 23 print(lst) 24 25 # 把马虎疼换成马化疼 26 lst[3][0] = lst[3][0].replace("虎", "化") 27 print(lst[3][0]) 28 29 lst[3][1].append("雪碧") 30 print(lst)
二、元组
俗称不可变的列表,又被称为只读列表,由()组成,里面可以放任何的数据类型。
元组可以查询,循环,切片,但就是不能改。
特点:不可变
注意:这里元组的不可变的意思是子元素不可变,而子元素内部的子元素是可以变,这取决于子元素是否是可变对象。
元组中如果只有一个元素。一定要添加一个逗号, 否则就不是元组
1 tu = (1) 2 print(type(tu)) #<class 'int'> 3 tu = (1,) 4 print(type(tu)) #<class 'tuple'>
三、range
range可以帮我们获取到一组数据,通过for循环能够获取到这些数据
range(n) : [0,n)
range(m, n) :[m,n)
range(m, n, p) :从m到n,没隔p个取一个