比你优秀的人比你还好努力——Python列表

07——列表

1. 序列(sequence)

1.1 基本概念

• 序列是Python中最基本的一种数据结构。序列用于保存一组有序的数据,所有的数据在序列当中都有一个唯一的位置(索引)并且序列中的数据会按照添加的顺序来分配索引
• 数据结构指计算机中数据存储的方式

1.2 序列的分类

• 可变序列(序列中的元素可以改变):例如 列表(list)字典(dict)
• 不可变序列(序列中的元素不能改变):例如 字符串(str)元组(tuple)

2. 列表(list)

• 列表是Python中的一个对象
• 列表的作用
• 列表中可以保存多个有序的数据
• 列表是用来存储对象的对象

2.1 列表的使用

• 列表的创建:通过[]来创建一个空列表

lst = []
print(lst)  #返回结果:[]

2.2 切片

• 切片是指从现有列表中获得一个子列表
• 通过切片来获取指定的元素
• 语法: 列表[起始 : 结束 : 步长]
• 通过切片获取元素时,会包括起始位置的元素,不会包括结束位置的元素

#通过切片获取元素时,会包括起始位置的元素,不会包括结束位置的元素
hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长']
#做切片操作时,总会返回一个新的列表,不会影响原来的列表
print(hero[0:2])  #返回:['钢铁侠','绿巨人']
print(hero[2:4])  #返回:['蜘蛛侠','黑寡妇']
print(hero)  #返回:['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长']

• 起始位置和结束位置的索引可以不写

# 起始位置和结束位置的索引可以不写
# 如果我省略结束位置,则会从当前的开始位置一直截取到最后
print(hero[1:])  #返回:['绿巨人', '蜘蛛侠', '黑寡妇', '蚁人', '美国队长']

• 如果省略结束位置, 则会从当前的开始位置一直截取到最后
• 如果省略开始位置, 则会从第一个元素截取到结束的元素,但是不包括结束的元素

如果省略开始位置,则会从第一个元素截取到结束位置的元素,但是不包括结束的元素
print(hero[:3])  #返回:['钢铁侠', '绿巨人', '蜘蛛侠']

• 如果开始位置和结束位置都省略, 则则会从第一个元素开始截取到最后一个元素

如果开始位置和结束位置都省略,则会从第一个元素截取到最后一个元素
print(hero[:])  #返回:['钢铁侠', '绿巨人', '蜘蛛侠', '黑寡妇', '蚁人', '美国队长']

• 步长表示每次获取元素的间隔,默认是1(可以省略不写)

# 步长表示每次获取元素的间隔 默认为1 可以省略
# 步长不能是0 但是可以是负数
# 如果步长是负数 则会从列表的后面像前面获取元素
print(hero[0:5:1])  #返回:['钢铁侠', '绿巨人', '蜘蛛侠', '黑寡妇', '蚁人']
print(hero[::0]) #ValueError: slice step cannot be zero 步长不能是0
print(hero[::-1])  #返回:['美国队长', '蚁人', '黑寡妇', '蜘蛛侠', '绿巨人', '钢铁侠']

• 步长不能是0,但可以是是负数

3. 通用操作

• + 和 *
• + 可以将两个列表拼接成一个列表

# +*
# +表示可以将2个列表拼接成一个列表
# *将列表中的元素指定重复的次数
lst = [1,2,3] + [4,5,6]
print(lst)  #返回:[1, 2, 3, 4, 5, 6]

• * 可以将列表重复指定的次数 (注意2个列表不能够做乘法,要和整数做乘法运算)

# lst = [4,5,6] * [1,2,3]
print(lst)  #返回:TypeError: can't multiply sequence by non-int of type 'list'
hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长']

• in 和 not in

in 和 not in
# in 表示用来检查指定元素是否在列表当中,如果在返回True,如果不在返回False
# not in  表示用来检查指定元素是否不在列表当中,如果不在返回True,如果在返回False
print('钢铁侠'not in hero)  #False ,表示钢铁侠不在hero中,所以返回Flase
hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长']
print('钢铁侠'in hero)   #返回结果:True

• in用来检查指定元素是否在列表当中
• not in 用来检查指定元素是否不在列表当中
• len() 获取列表中元素的个数

# len()获取列表中的多个元素的长度
print(len(hero))  #返回结果为6,表示长度为6

• max() 获取列表中最大值

# max() 获取列表中的最大值
l = [10,15,7,20,12,6]
print(max(l))  #返回:20

• min() 获取列表中最小值

# min() 获取列表中的最小值
l = [10,15,7,20,12,6]
print(min(l))  #返回:6

• list.index(x[, start[, end]])

ero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长','蜘蛛侠','蜘蛛侠']
# 方法和函数的区别 方法必须通过 对象.方法() xxx.yyy() zzz()
# s.index(x[, i[, j]]) # 获取指定元素在列表当中的位置
# 第二个参数 表示查找的起始位置 表示查找的介绍位置
print(hero.index('蜘蛛侠',3,7))  #返回:6

• 第一个参数 获取指定元素在列表中的位置
• 第二个参数 表示查找的起始位置
• 第三个参数 表示查找的结束位置
• list.count(x) 统计指定元素在列表中出现的个数

hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长','蜘蛛侠','蜘蛛侠']
# s.count(x) 统计指定元素在列表中出现的次数
print(hero.count('蝙蝠侠'))  #返回:0

4. 修改列表

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

5. 列表的方法

• append() 像列表的最后添加一个元素

hero = ['钢铁侠','绿巨人','蜘蛛侠']
print('修改前',hero)   #返回:修改前 ['钢铁侠', '绿巨人', '蜘蛛侠']
# append()向列表最后添加一个元素
hero.append('黑寡妇')
print('修改后',hero)   #返回:修改后 ['钢铁侠', '绿巨人', '蜘蛛侠', '黑寡妇']

• insert(arg1,arg2) 像列表指定位置插入一个元素 参数1:要插入的位置 参数2:要插入的元素

# insert(参数一,参数二)向列表指定位置插入一个元素,参数一:要插入的的位置,参数二:要插入的元素
hero.insert(2,'黑寡妇')
print(hero)   #返回:['钢铁侠', '绿巨人', '黑寡妇', '蜘蛛侠', '黑寡妇']

• extend(iterable) 使用一个新的序列来扩展当前序列(它会将该序列的中元素添加到列表中) 参数需要传递一个序列

# extend()使用新的序列来扩展当前的序列
hero.extend(123)
print(hero)   #返回结果会报错:TypeError: 'int' object is not iterable
hero.extend(['黑寡妇','蚁人'])
hero += ['黑寡妇','蚁人']
print(hero)  #返回:['钢铁侠', '绿巨人', '黑寡妇', '蜘蛛侠', '黑寡妇', '黑寡妇', '蚁人', '黑寡妇', '蚁人']

• pop() 根据索引删除并返回指定元素

hero = ['钢铁侠','绿巨人','蜘蛛侠']
print(hero)  #返回:['钢铁侠', '绿巨人', '蜘蛛侠']
# pop()根据索引删除并返回指定的元素
result = hero.pop(2)
print('result = ',result)  #返回:result =  蜘蛛侠
hero.pop()  #如果不穿索引值就删除最后一个元素

• remove() 删除指定元素 (如果相同值的元素有多个,只会删除第一个)

# remove() 删除指定值的元素
# 如果相同值的元素有多个,只会删除第一个
hero.remove('绿巨人')
print(hero)  #返回:['钢铁侠']

• reverse() 翻转列表

# reverse()用来翻转列表
hero = ['钢铁侠','绿巨人','蜘蛛侠']
hero.reverse()
print(hero)  #返回:['蜘蛛侠', '绿巨人', '钢铁侠']

• sort(key=None,reverse=False) 用来对列表中的元素进行排序 reverse:True反序;False 正序

# sort()用来对列表中的元素进行排序
lst = list('987132465')
print('修改前',lst)  #返回:['9', '8', '7', '1', '3', '2', '4', '6', '5']
lst.sort(reverse=True)
print('修改后',lst)  #返回:修改后 ['9', '8', '7', '6', '5', '4', '3', '2', '1']
lst.sort(reverse=False)
print('修改后',lst)   #返回:修改后 ['1', '2', '3', '4', '5', '6', '7', '8', '9']

6. 遍历列表

6.1 for循环

• 通过for循环来遍历列表
语法
for 变量 in 序列(遍历的规则):
代码块
• 注意: for循环的代码块会执行多次,序列中有几个元素就会执行几次。每执行一次就会将序列中的一个元素赋值给变量,所以我们可以通过变量来获取列表中的元素

6.2 range(start, stop[, step])

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(5) 等价于 range(0, 5) 等价于range(0,5,1)
lit = [1,2,3,4,5,6,7,8,9]
# # 获取列表当中的奇数
for i in range(0,9,2):
     print(lit[i])  #返回:1 3 5 7 9
for i in range(5):
    print(lit[i])  #返回:1 2 3 4 5

参数说明
• ·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)
思维导图如下:在这里插入图片描述https://www.edrawsoft.cn/viewer/public/s/0eb62389280650思维导图

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值