如何处理列表的部分元素?

想对大家说的话:大家好呀,我是耶耶

在这里,我会将Python代码像拆解精密玩具一样,一步步剖析,确保每一步的来龙去脉都清晰可见。

我会详细解释为什么选择特定的关键字和结构,通过对比不同类型的代码片段,让你不仅知其然,更知其所以然!!!

拜托大家给我点一个关注!让我们一起进步吧!!!


上期本期学习了怎么创建数值列表,今天给大家讲一下如何处理列表的部分元素~


前言:以处理列表的部分元素——Python称之为切片。

切片

要创建切片,可指定要使用的第一个元素和最后一个元素的索引。与函数range()一样,Python 在到达你指定的第二个索引前面的元素后停止。要输出列表中的前三个元素,需要指定索引0~3, 这将输出分别为0、1和2的元素。

下面的示例处理的是一个运动队成员列表:

players = ['charles', 'martina', 'michael', 'florence', 'eli'] 
 print(players[0:3]) 
['charles', 'martina', 'michael']

你可以生成列表的任何子集,例如,如果你要提取列表的第2~4个元素,可将起始索引指定 为1,并将终止索引指定为4:

#players = ['charles', 'martina', 'michael', 'florence', 'eli'] 
print(players[1:4]) 

这一次,切片始于'marita',终于'florence':

['martina', 'michael', 'florence'] 

如果你没有指定第一个索引,Python将自动从列表开头开始:

#players = ['charles', 'martina', 'michael', 'florence', 'eli'] 
print(players[:4])

由于没有指定起始索引,Python从列表开头开始提取:

 
['charles', 'martina', 'michael', 'florence']

要让切片终止于列表末尾,也可使用类似的语法。例如,如果要提取从第3个元素到列表末 尾的所有元素,可将起始索引指定为2,并省略终止索引:

players = ['charles', 'martina', 'michael', 'florence', 'eli'] 
print(players[2:]) 

Python将返回从第3个元素到列表末尾的所有元素:

['michael', 'florence', 'eli']

无论列表多长,这种语法都能够让你输出从特定位置到列表末尾的所有元素。本书前面说过,负数索引返回离列表末尾相应距离的元素,因此你可以输出列表末尾的任何切片。例如,如果你要输出名单上的最后三名队员,可使用切片players[-3:]:

players = ['charles', 'martina', 'michael', 'florence', 'eli'] 
print(players[-3:]) 

上述代码打印最后三名队员的名字,即便队员名单的长度发生变化,也依然如此。

遍历切片

如果要遍历列表的部分元素,可在for循环中使用切片。在下面的示例中,我们遍历前三名 队员,并打印他们的名字:

players = ['charles', 'martina', 'michael', 'florence', 'eli'] 
print("Here are the first three players on my team:") 
 for player in players[:3]: 
print(player.title()) 
Here are the first three players on my team: 
Charles 
Martina 
Michael

在很多情况下,切片都很有用。例如,编写游戏时,你可以在玩家退出游戏时将其最终得分 加入到一个列表中。然后,为获取该玩家的三个最高得分,你可以将该列表按降序排列,再创建 一个只包含前三个得分的切片。处理数据时,可使用切片来进行批量处理;编写Web应用程序时, 可使用切片来分页显示信息,并在每页显示数量合适的信息。

复制列表

你经常需要根据既有列表创建全新的列表。下面来介绍复制列表的工作原理,以及复制列表 可提供极大帮助的一种情形。

要复制列表,可创建一个包含整个列表的切片,方法是同时省略起始索引和终止索引([:])。 这让Python创建一个始于第一个元素,终止于最后一个元素的切片,即复制整个列表。

例如,假设有一个列表,其中包含你最喜欢的四种食品,而你还想创建另一个列表,在其中包含一位朋友喜欢的所有食品。不过,你喜欢的食品,这位朋友都喜欢,因此你可以通过复制来创建这个列表:

my_foods = ['pizza', 'falafel', 'carrot cake'] 
 friend_foods = my_foods[:] 
print("My favorite foods are:") 
print(my_foods) 
print("\nMy friend's favorite foods are:") 
print(friend_foods) 

我们首先创建了一个名为my_foods的食品列表,然后创建了一个名为friend_foods的 新列表。我们在不指定任何索引的情况下从列表my_foods中提取一个切片,从而创建了 这个列表的副本,再将该副本存储到变量friend_foods中。打印每个列表后,我们发现它们包含的食品相同:

My favorite foods are: 
['pizza', 'falafel', 'carrot cake'] 
My friend's favorite foods are: 
['pizza', 'falafel', 'carrot cake'] 

为核实我们确实有两个列表,下面在每个列表中都添加一种食品,并核实每个列表都记录了 相应人员喜欢的食品:

my_foods = ['pizza', 'falafel', 'carrot cake'] 
friend_foods = my_foods[:] 
my_foods.append('cannoli')  
friend_foods.append('ice cream') 
print("My favorite foods are:") 
print(my_foods) 
print("\nMy friend's favorite foods are:") 
print(friend_foods) 

与前一个示例一样,我们首先将my_foods的元素复制到新列表friend_foods中,接下来,在每个列表中都添加一种食品:在列表my_foods中添加'cannoli',而在friend_foods 中添加'ice cream',最后,打印这两个列表,核实这两种食品包含在正确的列表中。

My favorite foods are: 
['pizza', 'falafel', 'carrot cake', 'cannoli'] 
My friend's favorite foods are:  
['pizza', 'falafel', 'carrot cake', 'ice cream']

如代码所示:'cannoli'包含在你喜欢的食品列表中,而'ice cream'没有,'ice cream'包含在你朋友喜欢的食品列表中,而'cannoli'没有。倘若我们只是简单地将 my_foods赋给friend_foods,就不能得到两个列表。例如,下例演示了在不使用切片的情况下复制列表的情况:

my_foods = ['pizza', 'falafel', 'carrot cake'] 
#这行不通 
friend_foods = my_foods 
my_foods.append('cannoli') 
friend_foods.append('ice cream') 
print("My favorite foods are:") 
print(my_foods) 
print("\nMy friend's favorite foods are:") 
print(friend_foods) 

这里将my_foods赋给friend_foods,而不是将my_foods的副本存储到friend_foods。这种语法实际上是让Python将新变量friend_foods关联到包含在my_foods中的列表,因此这两个变量都指向同一个列表。鉴于此,当我们将'cannoli'添加到my_foods中时,它也将出现在 friend_foods中;同样,虽然'ice cream'好像只被加入到了friend_foods中,但它也将出现在这 两个列表中。

My favorite foods are: 
['pizza', 'falafel', 'carrot cake', 'cannoli', 'ice cream'] 
My friend's favorite foods are: 
['pizza', 'falafel', 'carrot cake', 'cannoli', 'ice cream'] 

输出表明,两个列表是相同的,这并非我们想要的结果。


OK啦,以上就是本期的全部内容,如果对大家有帮助的话请大家给小编点个赞和关注哟~感谢小伙伴们阅读到这里,我们下期再见!

你可能感兴趣的:(python,numpy,开发语言)