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

目录

上一篇文章介绍了列表操作的常用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

上一篇:对象类型和Map相互转化 对象集合和Map集合互相转化


下一篇:「机器学习算法的数学解析与Python实现」KNN分类算法