上一篇文章介绍了列表操作的常用API,本篇文章再说明一些列表(List)其他一些很常用的操作。

1、通过切片对列表的操作

注意:在给切片进行赋值时,只能使用序列赋值。

(1)通过切片对列表进行修改

"""
1、使用一个序列替换,一个列表的片段。
注意:不过替换序列的当度是多少,
都完全替换列表中的指定位置,前闭后开。 输出结果:
修改前: ['孙悟空', '猪八戒', '沙和尚', '唐僧']
修改后: ['牛魔王', '红孩儿', '沙和尚', '唐僧']
"""
stus = ['孙悟空','猪八戒','沙和尚','唐僧']
print("修改前:", stus)
stus[0:2] = ['牛魔王','红孩儿']
# stus[0:2] = ['牛魔王','红孩儿','二郎神','白骨精']
# stus[0:2] = ['牛魔王']
print("修改后:", stus) """
2、向列表中指定位置插入一个序列 输出结果:
修改前: ['孙悟空', '猪八戒', '沙和尚', '唐僧']
修改后: ['牛魔王', '孙悟空', '猪八戒', '沙和尚', '唐僧']
"""
# 向索引为0的位置插入元素
stus = ['孙悟空','猪八戒','沙和尚','唐僧']
print("修改前:", stus)
stus[0:0] = ['牛魔王']
# stus[2:2] = ['牛魔王']
print("修改后:", stus) """
3、当设置了步长时,
序列中元素的个数必须和切片中元素的个数一致。 输出结果:
修改前: ['孙悟空', '猪八戒', '沙和尚', '唐僧', '蜘蛛精', '白骨精']
修改后: ['牛魔王', '猪八戒', '红孩儿', '唐僧', '二郎神', '白骨精']
"""
stus = ['孙悟空','猪八戒','沙和尚','唐僧','蜘蛛精','白骨精']
print("修改前:", stus)
stus[::2] = ['牛魔王','红孩儿','二郎神']
# stus[::2] = ['牛魔王','红孩儿'] # 报错
# stus[2::2] = ['牛魔王','红孩儿'] # 正常
print("修改后:", stus)
"""
当stus[::2],表示全列表,每两步选一个元素,
列表一个有6个元素,
所以该切片一个有三个元素。
所以后边赋值三个元素的序列就能够成功。
当stus[::2],同理切片中元素是3,
你赋值两个元素的序列,不相等,就报错。
当stus[2::2], 切片中元素是2,
你赋值两个元素的序列,相等,则正常修改。
"""

(2)通过切片对列表进行删除

"""
# 在列表中删除切片中的元素
输出结果:
修改前: ['孙悟空', '猪八戒', '沙和尚', '唐僧']
修改后: ['沙和尚', '唐僧']
修改后: ['唐僧']
修改后: ['唐僧']
"""
stus = ['孙悟空','猪八戒','沙和尚','唐僧']
print("修改前:", stus)
del stus[0:2]
print("修改后:", stus)
del stus[::2]
print("修改后:", stus)
stus[1:3] = []

(3)注意

以上操作,只适用于可变序列。

包括列表中学习的方法,只能支持可变序列。

2、列表的循环遍历

什么是遍历,就是安顺序依次访问到序列当中的每一个数据。换句话说遍历指的就是将列表中的所有元素一个一个的取出来。

需求:依次打印列表中的各个数据。

(1)while循环遍历

"""
输出结果:
Tom
Lily
Rose
"""
name_list = ['Tom', 'Lily', 'Rose'] i = 0
while i < len(name_list):
print(name_list[i])
i += 1 """
如果遍历的下标越界,则会抛出异常,
IndexError: list index out of range
"""
name_list = ['Tom', 'Lily', 'Rose']
i = 0
while i < len(name_list)+2:
print(name_list[i])
i += 1

(2)for循环遍历

只要是序列,就都可以使用for循环遍历。

"""
输出结果:
Tom
Lily
Rose
"""
name_list = ['Tom', 'Lily', 'Rose'] for i in name_list:
print(i)

3、列表嵌套

所谓列表嵌套指的就是一个列表里面包含了其他的子列表。

应用场景:要存储班级一、二、三3个班级学生姓名,且每个班级的学生姓名在一个列表。

name_list = [['小明', '小红', '小绿'], ['Tom', 'Lily', 'Rose'], ['张三', '李四', '王五']]

思考: 如何查找到数据"李四"?

# 第一步:按下标查找到李四所在的班级列表
# 结果:['张三', '李四', '王五']
print(name_list[2]) # 第二步:从李四所在的班级列表里面,再按下标找到数据李四
# 结果:李四
print(name_list[2][1])

4、综合示例

需求:有三个办公室,8位老师,8位老师随机分配到3个办公室

"""
步骤:
1. 准备数据
1.1 8位老师 -- 列表
1.2 3个办公室 - 列表嵌套 2. 分配老师到办公室
随机分配,调用random函数
就是把老师的名字写入到办公室列表中,
换句话说就是向办公室列表追加老师名字。 3. 验证是否分配成功
打印办公室详细信息:每个办公室的人数和对应的老师名字。
""" import random # 1. 准备数据,老师和办公室
teachers = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H']
offices = [[], [], []] # 2. 分配老师到办公室
# 遍历老师列表数据,取到的每个老师随机放到一个办公室列表。
for name in teachers:
# 列表追加数据 -- append(选择) extend insert
# num随机办公室号
num = random.randint(0, 2)
offices[num].append(name) # 以上代码,老师已经分配完办公室,下面只是输出格式。 # 为了更贴合生活,把各个办公室子列表加一个办公室编号 1, 2, 3
i = 1 # 办公室编号
# 3. 验证是否分配成功
for office in offices:
# 打印办公室人数
# 子列表数据的个数用len()获取
print(f'办公室{i}的人数是{len(office)},老师分别是:')
# 打印每个办公室内老师的名字
for name in office:
print(name)
i += 1

『无为则无心』Python序列 — 19、Python列表的其他操作(切片和遍历)的更多相关文章

  1. 『无为则无心』Python序列 — 18、Python列表概念及常用操作API

    目录 1.列表的概念 (1)列表的定义 (2)列表的应用场景 (3)列表的定义格式 2.列表的常用操作 (1)列表的查找 1)通过下标查找 2)通过方法查找 3)判断是否存在 (2)列表的增加 @1. ...

  2. 『无为则无心』Python序列 — 23、Python序列的公共API

    目录 1.运算符 @1.+加号 @2.*乘号 @3.in或not in 2.公共方法 @1.len()方法 @2.del和del() @3.max()方法 @4.min()方法 @5.range() ...

  3. 『无为则无心』Python序列 — 24、Python序列的推导式

    目录 1.列表推导式 (1)快速体验 (2)带if的列表推导式 (3)多个for循环实现列表推导式 2.字典推导式 (1)创建一个字典 (2)将两个列表合并为一个字典 (3)提取字典中目标数据 3.集 ...

  4. 『无为则无心』Python基础 — 62、Python中自定义迭代器

    目录 1.迭代器对象的创建 2.实际应用案例 3.总结: 1.迭代器对象的创建 迭代器是一种可以被遍历的对象,并且能够作用于next()函数,迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问 ...

  5. 『无为则无心』Python基础 — 10、Python字符串的格式化输出

    目录 1.什么是格式化输出 2.Python格式化输出的五种方式 方式一:字符串之间用+号拼接 方式二:print()函数可同时输出多个字符串 方式三:占位符方式 方式四:f格式化方式(推荐) 方式五 ...

  6. 『无为则无心』Python基础 — 12、Python运算符详细介绍

    目录 1.表达式介绍 2.运算符 (1)运算符的分类 (2)算数运算符 (3)赋值运算符 (4)复合赋值运算符 (5)比较运算符 3.逻辑运算符 拓展1:数字之间的逻辑运算 拓展2:Python中逻辑 ...

  7. 『无为则无心』Python基础 — 4、Python代码常用调试工具

    目录 1.Python的交互模式 2.IDLE工具使用说明 3.Sublime3工具的安装与配置 (1)Sublime3的安装 (2)Sublime3的配置 4.使用Sublime编写并调试Pytho ...

  8. 『无为则无心』Python基础 — 6、Python的注释

    目录 1.注释的作用 2.注释的分类 单行注释 多行注释 3.注释的注意事项 4.什么时候需要使用注释 5.总结 提示:完成了前面的准备工作,之后的文章开始介绍Python的基本语法了. Python ...

  9. 『无为则无心』Python基础 — 7、Python的变量

    目录 1.变量的定义 2.Python变量说明 3.Python中定义变量 (1)定义语法 (2)标识符定义规则 (3)内置关键字 (4)标识符命名习惯 4.使用变量 1.变量的定义 程序中,数据都是 ...

随机推荐

  1. 痞子衡嵌入式:串行NOR Flash的Continuous read模式下软复位后i.MXRT无法启动问题解决方案之RESET#

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT上使能NOR Flash的Continuous read模式在软复位后无法正常启动问题的解决经验. 前一篇文章 <在i ...

  2. 使用 parted 命令可以查看系统采用什么类型的分区表 gpt/mbr/msdos/ext/ext/ext2/ext3/ext4

      Linux磁盘表示方式 Linux以字母标识磁盘的个数 a:第一块 b:第二块 Linux用数字标识分区:1-4标识主分区或扩展分区 逻辑分区从5开始 例如:sda.sda1.sda2 低级格式化 ...

  3. 云计算OpenStack核心组件---cinder存储服务(10)

    一.cinder介绍 1.Block Storage 操作系统获得存储空间的方式一般有两种: (1)通过某种协议(SAS,SCSI,SAN,iSCSI 等)挂接裸硬盘,然后分区.格式化.创建文件系统: ...

  4. nvm、nrm、npm 安装和使用详解

    一.nvm的安装和使用   nvm全称Node Version Manager是 Nodejs 版本管理器,它让我们能方便的对 Nodejs 的版 本进行切换. nvm 的官方版本只支持 Linux ...

  5. mysql基础之查询缓存、存储引擎

    一.查询缓存 "查询缓存",就是将查询的结果缓存下载,如果查询语句完全相同,则直接返回缓存中的结果. 如果应用程序在某个场景中,需要经常执行大量的相同的查询,而且查询出的数据不会经 ...

  6. 【Java】Files.readAllBytes(Path) 遇见的坑

    Files.readAllBytes(Path)方法把整个文件读入内存,此方法返回一个字节数组,还可以把结果传递给String的构造器,以便创建字符串输出. 在针对大文件的读取的时候,可能会出现内存不 ...

  7. Centos6.5 修改主机名(hostname)

    centos6需要修改两处:一处是/etc/sysconfig/network,另一处是/etc/hosts,只修改任一处会导致系统启动异常.首先切换到root用户. /etc/sysconfig/n ...

  8. 分布式锁中的王者方案-Redisson

    上篇讲解了如何用 Redis 实现分布式锁的五种方案,但我们还是有更优的王者方案,就是用 Redisson. 缓存系列文章: 缓存实战(一):20 图 |6 千字|缓存实战(上篇) 缓存实战(二):R ...

  9. C# DeepClone 深拷贝

    常规利用反射进行克隆 public static T CloneModel<T>(T oModel) { var oRes = default(T); var oType = typeof ...

  10. GO学习-(23) Go语言操作MySQL + 强大的sqlx

    Go语言操作MySQL MySQL是业界常用的关系型数据库,本文介绍了Go语言如何操作MySQL数据库. Go操作MySQL 连接 Go语言中的database/sql包提供了保证SQL或类SQL数据 ...