课时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的变量就像一个标签,就一个名字而已,贴哪是哪,指哪打哪,呃,我还是给大家伙画个图好。

posted @ 2018-07-29 18:08  那是个好男孩  阅读(1129)  评论(0编辑  收藏  举报