1.列表切片

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

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

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

复制代码

处的代码打印该列表的一个切片,其中只包含三名队员。输出也是一个列表,其中包含前三名队员:

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

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

复制代码

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

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

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

复制代码

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

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

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

复制代码

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

无论列表多长,这种语法都能够让你输出从特定位置到列表末尾的所有元素。本书前面说过,负数索引返回离列表末尾相应距离的元素,因此你可以输出列表末尾的任何切片。

例如,如果你要输出名单上的最后三名队员,可使用切片 players[-3:] :

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

复制代码

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

2.遍历切片

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

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

复制代码

此处的代码没有遍历整个队员列表,而只遍历前三名队员:

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

3. 复制列表

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

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

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

  1. my_foods = ['pizza', 'falafel', 'carrot cake']
  2. friend_foods = my_foods[:]
  3. print("My favorite foods are:")
  4. print(my_foods)
  5. print("My friend's favorite foods are:")
  6. print(friend_foods)

复制代码

我们首先创建了一个名为 my_foods 的食品列表,然后创建了一个名为 friend_foods 的新列表。我们在不指定任何索引的情况下从列表 my_foods 中提取

一个切片,从而创建了这个列表的副本,再将该副本存储到变量 friend_foods 中。打印每个列表后,我们发现它们包含的食品相同:

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

  1. my_foods = ['pizza', 'falafel', 'carrot cake']
  2. friend_foods = my_foods[:]
  3. my_foods.append('cannoli')
  4. friend_foods.append('ice cream')
  5. print("My favorite foods are:")
  6. print(my_foods)
  7. print("My friend's favorite foods are:")
  8. print(friend_foods)

复制代码

与前一个示例一样,我们首先将 my_foods 的元素复制到新列表 friend_foods 中。接下来,在每个列表中都添加一种食品:在列表 my_foods 中添加 'cannoli'

,而在 friend_foods 中添加 'ice cream' 。最后,打印这两个列表,核实这两种食品包含在正确的列表中。

第一个输出表明, 'cannoli' 包含在你喜欢的食品列表中,而 'ice cream' 没有。第二个输出表明, 'ice cream' 包含在你朋友喜欢的食品列表中,而 'cannoli' 没

有。倘若我们只是简单地将 my_foods 赋给 friend_foods ,就不能得到两个列表。例如,下例演示了在不使用切片的情况下复制列表的情况:

  1. my_foods = ['pizza', 'falafel', 'carrot cake']
  2. friend_foods = my_foods
  3. my_foods.append('cannoli')
  4. friend_foods.append('ice cream')
  5. print("My favorite foods are:")
  6. print(my_foods)
  7. print("My friend's favorite foods are:")
  8. 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 中,但它也将出现在这两个列表中。

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

注意  现在暂时不要考虑这个示例中的细节。基本上,当你试图使用列表的副本时,如果结果出乎意料,请确认你像第一个示例那样使用切片复制了列表

python 切片_零基础学python_11_列表(切片+遍历切片+复制)相关推荐

  1. 第一门语言学python好_零基础学编程,哪一门语言比较适合入门?

    最近,有不少小伙伴问我,说零基础学编程,第一门语言学哪个好?有人推荐学Python,理由是Python简单,对新人友好,上手快,那Python到底适不合适新人学呢. 我今天就这个问题给大家稍微的展开一 ...

  2. python一到10整数的平方和_零基础学python_10_列表(创建数值列表 )

    创建数值列表 需要存储一组数字的原因有很多,例如,在游戏中,需要跟踪每个角色的位置,还可能需要跟踪玩家的几个最高得分.在数据可视化中,处理的几乎都是由数字(如温度.距离.人口数量.经度和纬度等)组成的 ...

  3. 零基础学python张志强_零基础学Python最新章节_张志强著_掌阅小说网

    1.5 Python的开发工具 Python的开发工具非常丰富,有许多强大的IDE(Integrated Development Environment)工具,如Komodo.PythonWin.Ec ...

  4. 冒泡排序python例题_零基础学python 15 经典算法:冒泡排序法(课后习题答案)...

    这节课我们对于冒泡排序法的课后习题进行一下解答: 回顾一下我们的题目: 上节课我们学习的冒泡排序法,是让我们的list从小到大进行排列,这次我们的任务是,请对冒泡排序法进行一定的修改,加一个参数,让它 ...

  5. 聊聊零基础的我是如何学python的_零基础学python-4.3 对象的比较

    这一章节我们聊聊对象的比较,我们分为两部分: 1.值的比较 从上图我们看见,一般值的比较都是使用==.>. 除此之外,python还实现了多个比较操作符 2.对象本身的比较(引用的比较) pyt ...

  6. python自学步骤-零基础学Python应该学习哪些入门知识及学习步骤安排

    众所周知,Python以优雅.简洁著称,入行门槛低,可以从事Linux运维.Python Web网站工程师.Python自动化测试.数据分析.人工智能等职位!就目前来看,Python岗位人才缺口高达4 ...

  7. python 智能造句_[零基础学Python]正规地说一句话

    小孩子刚刚开始学说话的时候,常常是一个字一个字地开始学,比如学说"饺子",对他/她来讲,似乎有点难度,大人也聪明,于是就简化了,用"饺饺"来代替,其实就是让孩子 ...

  8. c字符串中包含双引号_零基础学Python:一文看懂数字和字符串

    来源:大数据DT 本文约2000字,建议阅读6分钟 数据类型是构成编程语言语法的基础.[ 导读 ]数据类型是构成编程语言语法的基础.不同的编程语言有不同的数据类型,但都具有常用的几种数据类型.Pyth ...

  9. python培训一般多久_零基础学python需要多久

    一:明确自己的学习目标.不管我们学习什么样的知识,都要对自己的学习目标有一个明确的认识.只有这样才能朝着目标持续的前进,少走弯路,从而在学习的过程中得到提升,享受整个学习的乐趣. 二:基础的Pytho ...

最新文章

  1. linux下mysql修改字符集,远程连接
  2. 【Paper】2014_多智能体系统一致性问题研究_唐骥宇
  3. cache与buffer
  4. 截取图片生成头像插件
  5. mysql子分区多少层_MySQL 子分区-阿里云开发者社区
  6. cesium根据输入高度设置相机camera视角高度
  7. 修改TFS与本地源代码映射路径
  8. Elasticsearch7.15.2 安装、部署(linux环境)
  9. PyCharm2019.1.1安装(Ubuntu16.04)
  10. PHP 接收 UDP包_UDP详解(广播,组播)(转)
  11. sql concat函数_使用SQL Plus(+)和SQL CONCAT函数SQL Server CONCATENATE操作
  12. 堆插入和删除的简单实现
  13. CentOS下Red5安装
  14. java 代码混淆原理
  15. 移动web前端开发注意事项
  16. 消息队列之kafka在虚拟机安装使用与整合springboot详解教程
  17. Eclipse设置项目编码格式的两种方式
  18. sqlite引用SQLite.Interop.dll出错
  19. 教你如何鉴别原装和组装线孔耳机
  20. Hadoop3 - HDFS 文件存储策略

热门文章

  1. div iframe 显示html,IE中iframe标签显示在DIV之上的问题解决方案
  2. Mybatis 一连串提问,被面试官吊打了!
  3. Redis轻松实现秒杀系统
  4. Could not retrieve transaction isolation level from server
  5. Fields of Mathematics
  6. Python Socket(未编辑)
  7. java实现文件上传(使用FromData)
  8. 解决postman环境切换,自动获取api签名时间及签名
  9. Scoped CSS规范草案
  10. 利用nginx集群式部署服务器中,数据同步问题