课时11:列表:一个打了激素的数组2
目录:
一、从列表中获取元素
二、从列表删除元素
三、列表分片
四、列表分片的进阶玩法
五、 课时11课后习题及答案
**************************
一、从列表中获取元素
**************************
跟数组一样,我们可以通过元素的索引值(index)从列表获取单个元素,注意,列表索引值是从 0 开始的。
>>> name = ["鸡蛋","鸭蛋","鹅蛋","李狗蛋"] >>> name [0] '鸡蛋' >>> name[3] '李狗蛋' >>> name[1],name[3]=name[3],name[1] >>> name ['鸡蛋', '李狗蛋', '鹅蛋', '鸭蛋']
倒数第二行语句实现了 让“李狗蛋”和“鸭蛋”的位置互调。
***********************
二、从列表删除元素
***********************
从列表中删除元素,这里介绍三种方法:remove()、del和pop().先演示下用remove()删除元素:
>>> name = ["鸡蛋","鸭蛋","鹅蛋","李狗蛋"] >>> name.remove("李狗蛋") >>> name ['鸡蛋', '鸭蛋', '鹅蛋'] >>> name.remove("哈哈哈") Traceback (most recent call last): File "<pyshell#11>", line 1, in <module> name.remove("哈哈哈") ValueError: list.remove(x): x not in list
使用remove()删除元素,你并不需要知道这个元素在列表中的具体位置,只需要知道该元素存在列表中就可以了。如果要删除的元素根本不在列表中,程序就会报错。
remove()方法并不能指定删除某个位置的元素,这时要用del来实现:
>>> name = ["鸡蛋","鸭蛋","鹅蛋","李狗蛋"] >>> del name[1] >>> name ['鸡蛋', '鹅蛋', '李狗蛋']
注意:del是一个语句,不是一个列表的方法,所以你不必在它的后边加上小括号()。另外,如果你想删除整个列表,还可以直接用del加列表名删除:
>>> del name >>> name Traceback (most recent call last): File "<pyshell#16>", line 1, in <module> name NameError: name 'name' is not defined
最后,演示用pop()方法“弹出”元素:
>>> name = ["鸡蛋","鸭蛋","鹅蛋","李狗蛋"] >>> name.pop() '李狗蛋' >>> name.pop() '鹅蛋' >>> name.pop() '鸭蛋' >>> name ['鸡蛋'] >>> name.pop() '鸡蛋' >>> name []
大家看到啦,pop方法()默认是弹出列表中的最后一个元素。但是这个pop()方法其实还可以灵活应用,当你为它加上一个索引值作为参数时,它会弹出这个索引值所对应的元素:
>>> name = ["鸡蛋","鸭蛋","鹅蛋","李狗蛋"] >>> name.pop(2) '鹅蛋' >>> name ['鸡蛋', '鸭蛋', '李狗蛋']
***************
三、列表分片
***************
利用索引值,每次我们可以从列表获取一个元素,但是我们总是贪心的,如果一次性需要获取多个元素,有没有办法实现呢?利用列表分片,我们可以简单的实现这个要求。
>>> name = ["鸡蛋","鸭蛋","鹅蛋","李狗蛋"] >>> name[0:2] ['鸡蛋', '鸭蛋']
这里用一个冒号隔开两个索引值,左边是开始的位置,右边是结束的位置。这里需要注意一点,结束位置上的元素是不包括的。利用列表分片,得到一个原来列表的拷贝,原来的列表并没有发生改变。 列表分片也可以简写。
>>> name = ["鸡蛋","鸭蛋","鹅蛋","李狗蛋"] >>> name[:2] ['鸡蛋', '鸭蛋'] >>> name[0:2] ['鸡蛋', '鸭蛋'] >>> name[1:] ['鸭蛋', '鹅蛋', '李狗蛋'] >>> name[:] ['鸡蛋', '鸭蛋', '鹅蛋', '李狗蛋']
如果没有开始位置,Python会默认开始的位置是0.同样的道理,如果要得到从指定索引值到列表末尾的所有元素,把结束位置省去即可。如果没有索引值,而只是一个冒号,将得到整个列表的拷贝。 再一次强调:列表分片就是建立原列表的一个拷贝(或者说是副本),所以你想对列表做出某些修改,但同时你想保持原来那个列表,那么直接使用列表分片的方法来获取拷贝就很方便了。
****************************
四、列表分片的进阶玩法
****************************
分片操作实际上还可以接收第三个参数,其代表的是步长,默认情况下(不指定它的时候),该值为1。 注:例子中只有9个元素,索引值到了8.
>>> list1=[1,2,3,4,5,6,7,8,9] >>> list1[0:9:2] [1, 3, 5, 7, 9]
其实还可以写成list1[::2].如果步长为负数,例如-1,就相当于复制了一个反转的列表。
>>> list1=[1,2,3,4,5,6,7,8,9] >>> list1[::2] [1, 3, 5, 7, 9] >>> list1[::-1] [9, 8, 7, 6, 5, 4, 3, 2, 1] >>> list1 [1, 2, 3, 4, 5, 6, 7, 8, 9]
********************************
五、 课时11课后习题及答案
*********************************
测试题:
0. 下边的列表分片操作会打印什么内容?
>>> list1 = [1, 3, 2, 9, 7, 8]
>>> list1[2:5]
1. 请问 list1[0] 和 list1[0:1] 一样吗?
2. 如果你每次想从列表的末尾取出一个元素,并将这个元素插入到列表的最前边,你会怎么做?
3. 有些鱼油比较调皮,他说我想试试 list1[-3:-1] 会不会报错,怎么知道一试居然显示 [9, 7],这是怎么回事呢?
4. 在进行分片的时候,我们知道分片的开始和结束位置需要进行指定,但其实还有另外一个隐藏的设置:步长。
“在普通的分片操作中,步长默认设置为1,表示逐个遍历元素。其实我们可以人为调整步长以达到不可告人的秘密。”
>>> list1[0:6:2]
[1, 2, 7]
那么依你推测,关于步长的知识点还有哪些(很多知识点都是通用的)?
5. 课堂上小甲鱼说可以利用分片完成列表的拷贝 list2 = list1[:],那事实上可不可以直接写成 list2 = list1 更加简洁呢?
答案:
测试题答案:
0. 下边的列表分片操作会打印什么内容?
>>> list1 = [1, 3, 2, 9, 7, 8]
>>> list1[2:5]
[2, 9, 7](注意不包含 8 哦,因为 5-2==3,只有三个元素)
1. 请问 list1[0] 和 list1[0:1] 一样吗?
不一样,list1[0] 返回第0个元素的值,list1[0:1] 返回一个只含有第0个元素的列表。
>>> list1 = [0,1,2,3] >>> list1[0] 0 >>> list1[0:1] [0]
2. 如果你每次想从列表的末尾取出一个元素,并将这个元素插入到列表的最前边,你会怎么做?
>>> list1.insert(0, list1.pop())
这里我歪打正着产生了些许疑问,疑问和解决方案详见网址:网址(点击它!)
3. 有些鱼油比较调皮,他说我想试试 list1[-3:-1] 会不会报错,怎么知道一试居然显示 [9, 7],这是怎么回事呢?
Python 的列表很聪明,竟然支持负数索引,如图:
正常索引是从左到右索引,负数索引是从右到左。
4. 在进行分片的时候,我们知道分片的开始和结束位置需要进行指定,但其实还有另外一个隐藏的设置:步长。
1) 之前提到的“简洁”分片操作在这里有效:
>>> list1[::2]
[1, 2, 7]
2) 步长不能为0,要不就走不动了:
>>> list1[::0] Traceback (most recent call last): File "<pyshell#11>", line 1, in <module> list1[::0] ValueError: slice step cannot be zero
3) 步长可以是负数,改变方向(从尾部开始向左走)
>>> list1[::-2]
[8, 9, 3]
4) 步子太大容易扯着蛋......
5. 课堂上小甲鱼说可以利用分片完成列表的拷贝 list2 = list1[:],那事实上可不可以直接写成 list2 = list1 更加简洁呢?
千万不可以!
好的,为了大家都可以弄明白这个【必须理解】的概念,我啰嗦一下:
上节课我们提到使用分片创建列表的拷贝,例如:
1 >>> list1 = [1, 3, 2, 9, 7, 8] 2 >>> list2 = list1[:] 3 >>> list2 4 [1, 3, 2, 9, 7, 8] 5 >>> list3 = list1 6 >>> list3 7 [1, 3, 2, 9, 7, 8]
看上去貌似一样的,对吧?但事实上呢?我们利用列表的一个小伙伴做下修改,大家看一下差别:
>>> list1.sort() >>> list1 [1, 2, 3, 7, 8, 9]
看到吧,我们的list1已经从小到大排了个序,那list2和list3呢?
>>> list2
[1, 3, 2, 9, 7, 8]
可以看到我们使用分片的方式得到的list2很有原则、很有格调,并不会因为list1的改变而改变,这个原理我待会儿跟大家说,我们接着看下list3:
>>> list3
[1, 2, 3, 7, 8, 9]
大家可以看到了,真正的汉奸、墙头草是list3,Ta跟着list1改变了,这是为什么呢?
不知道大家还记不记得我们在讲解变量的时候说过,Python的变量就像一个标签,就一个名字而已,贴哪是哪,指哪打哪,呃,我还是给大家伙画个图好。