06 - 列表
1. 序列(sequence)
1.1基本概念
- 序列是Python中最基本的⼀种数据结构。序列⽤于保存⼀组有序的数据,所有的数据在序列当中都有⼀个唯⼀的位置(索引)并且序列中的数据会按照添加的顺序来分配索引
- 数据结构指计算机中数据存储的⽅式
1.2 序列的分类
- 可变序列(序列中的元素可以改变):例如 列表(list)字典(dict)
- 不可变序列(序列中的元素不能改变):例如 字符串(str)元组(tuple)
2. 列表(list)
- 列表是Python中的⼀个对象
- 列表的作⽤
- 列表中可以保存多个有序的数据
- 列表是⽤来存储对象的对象
2.1 列表的使用
- 列表的创建:通过[]来创建⼀个空列表
2.2 切片
- 切⽚是指从现有列表中获得⼀个⼦列表
- 通过切⽚来获取指定的元素
- 语法: 列表[起始 : 结束 : 步⻓]
- 通过切⽚获取元素时,会包括起始位置的元素,不会包括结束位置的元素
- 起始位置和结束位置的索引可以不写
- 如果省略结束位置, 则会从当前的开始位置⼀直截取到最后
- 如果省略开始位置, 则会从第⼀个元素截取到结束的元素,但是不包括结束的元素
- 如果开始位置和结束位置都省略, 则则会从第⼀个元素开始截取到最后⼀个元素
- 步⻓表示每次获取元素的间隔,默认是1(可以省略不写)
- 步⻓不能是0,但可以是是负数

3. 通用操作
-
加法+ 和 乘法 *
- 加法+可以将两个列表拼接成⼀个列表
- 乘法*可以将列表重复指定的次数 (注意2个列表不能够做乘法,要和整数做乘 法运算)
-
in 和 not in
-
in⽤来检查指定元素是否在列表当中
-
not in ⽤来检查指定元素是否不在列表当中
-
len() 获取列表中元素的个数
-
max() 获取列表中最⼤值
-
min() 获取列表中最⼩值

-
list.index(x[, start[, end]])
- 第⼀个参数 获取指定元素在列表中的位置
- 第⼆个参数 表示查找的起始位置
- 第三个参数 表示查找的结束位置
-
list.count(x) 统计指定元素在列表中出现的个数

4. 修改列表
- 通过切⽚来修改(起始就是给切⽚的内容重新赋值,但是赋值的内容必须是⼀ 个序列)
- 当设置了步⻓时,序列中元素的个数必须和切⽚中元素的个数保持⼀致
- 通过切⽚来删除元素
-
del list[起始 : 结束]

-
list = []

-
5. 列表的方法
-
append() 像列表的最后添加⼀个元素
-
insert(arg1,arg2) 像列表指定位置插⼊⼀个元素 参数1:要插⼊的位置 参数 2:要插⼊的元素
-
extend(iterable) 使⽤⼀个新的序列来扩展当前序列(它会将该序列的中元素 添加到列表中) 参数需要传递⼀个序列

-
pop() 根据索引删除并返回指定元素
-
remove() 删除指定元素 (如果相同值的元素有多个,只会删除第⼀个)
-
reverse() 翻转列表
-
sort(key=None,reverse=False) ⽤来对列表中的元素进⾏排序
-
reverse: True反序;False 正序

6. 遍历列表
6.1 for循环
- 通过for循环来遍历列表
语法
for 变量 in 序列(遍历的规则):
代码块
- 注意: for循环的代码块会执⾏多次,序列中有⼏个元素就会执⾏⼏次。每执⾏ ⼀次就会将序列中的⼀个元素赋值给变量,所以我们可以通过变量来获取列表中的元素
6.2 range(start, stop[, step])
参数说明
- start: 计数从 start 开始。默认是从 0 开始。例如range(5)等价于 range(0, 5);
- stop: 计数到 stop 结束,但不包括 stop。例如:range(0, 5) 是[0, 1, 2, 3, 4]没有5
- step:步⻓,默认为1。例如:range(0, 5) 等价于 range(0, 5, 1)
语法
语法:
for 变量 in range():
代码块
练习
- 1.现在有 a = [1,2,3,4,5,6] 不通过函数的形式实现列表的反转([6,5,4,3,2,1]) 并写出推导过程
a = [1, 2, 3, 4, 5, 6]
# 使用切片,翻转
ra = a[::-1]
print(f'原列表:{a}')
print(f'新列表:{ra}')

- 2.给用户9次机会 猜1 - 10 个数字随机来猜数字。如果随机的数字和用户输入的数字一致则表示正确,如果不一致则表示错误。最终结果要求用户怎么也猜不对
import random
print("***用户有9次机会,随机来猜1-10的数字***")
for i in range(1, 10):
player = int(input(f'用户第{i}次输入:'))
computer = random.randint(1, 9)
if player != computer:
print(f'电脑给出:{computer} 很可惜,用户猜错了,还有{9-i}次机会')
else:
# 循环直到电脑和用户的数不同
while True:
computer = random.randint(1, 9)
if player != computer:
print(f'电脑给出:{computer} 很可惜,用户猜错了,还有{9-i}次机会')
break

- 3.有两个列表 lst1 = [11, 22, 33] lst2 = [22, 33, 44]获取内容相同的元素
list_1 = [11, 22, 33]
list_2 = [22, 33, 44]
a = []
for i in list_1:
# 判断list_1是否在list_2中有相同元素
if i in list_2:
# 将相同的元素添加到新列表a
a.append(i)
print(a)

- 4.现在有8位老师,3个办公室,要求将8位老师随机的分配到三个办公室中
import random
list_1 = ['张三', '李四', '王五', '马六', '朱七', '方八', '徐一', '陈十']
a = []
b = []
c = []
for i in list_1:
# 随机办公室号
office_1 = random.randint(1, 3)
# 办公室号分配给每个老师列表每个元素
i = f'办公室{office_1}--' + i
# 将相同办公室号的元素添加到同一列表
if office_1 == 1:
a.append(i)
elif office_1 == 2:
b.append(i)
else:
c.append(i)
print(f'{a}\n{b}\n{c}\n')


- 5.现在有8位老师,3个办公室,要求将8位老师随机的分配到三个办公室中,要求每个办公室至少有一个老师(如果觉得上面的题不够写的话,写这个)
import random
while True:
list_1 = ['张三', '李四', '王五', '马六', '朱七', '方八', '徐一', '陈十']
a = []
b = []
c = []
for i in list_1:
# 随机办公室号
office_1 = random.randint(1, 3)
# 将相同办公室号的元素添加到同一列表
if office_1 == 1:
a.append(i)
elif office_1 == 2:
b.append(i)
else:
c.append(i)
# 每个办公室至少一位老师,因此列表a、b、c不能为空集
if a != [] and b != [] and c != []:
print(f'办公室1:{a}\n办公室2:{b}\n办公室3:{c}')
# 直到符合要求,循环结束
break

264

被折叠的 条评论
为什么被折叠?



