目录
- 序列
• 1.1 基本概念
• 1.2 序列的分类 - 列表(list)
• 2.1 列表的使用
• 2.2 切片 - 通用操作(方法和函数的差别)
- 修改列表
- 列表的方法
-
遍历列表
• 6.1 for循环
• 6.2 range()函数
1. 序列(sequence)
1.1 基本概念
• 序列是Python中最基本的一种数据结构。序列用于保存一组有序的数据,所有的数据在序列当中都有一个唯一的位置(索引)并且序列中的数据会按照添加的顺序来分配索引
• 数据结构指计算机中数据存储的方式
1.2 序列的分类
• 可变序列(序列中的元素可以改变):例如 列表(list)字典(dict)
• 不可变序列(序列中的元素不能改变):例如 字符串(str)元组(tuple)
2. 列表(list)
• 列表是Python中的一个对象
• 列表的作用
• 列表中可以保存多个有序的数据(任意对象)
• 列表是用来存储对象的对象
2.1 列表的使用
• 列表的创建:通过[]来创建一个空列表
2.2 切片
• 切片是指从现有列表中获得一个子列表
• 通过切片来获取指定的元素
• 语法: 列表[起始 : 结束 : 步长]
print(hero[0:5:1])#步长默认为1可以省略
print(hero[::0]) #ValueError: slice step cannot be zero 步长不能是0
print(hero[::-1])#从后向前获取元素
#['美国队长', '蚁人', '黑寡妇', '蜘蛛侠', '绿巨人', '钢铁侠']
• 通过切片获取元素时,会包括起始位置的元素,不会包括结束位置的元素
hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长']
print(hero[:3])
#['钢铁侠', '绿巨人', '蜘蛛侠']
• 起始位置和结束位置的索引可以不写
• 如果省略结束位置, 则会从当前的开始位置一直截取到最后
• 如果省略开始位置, 则会从第一个元素截取到结束的元素,但是不包括结束的元素
• 如果开始位置和结束位置都省略, 则则会从第一个元素开始截取到最后一个元素
• 步长表示每次获取元素的间隔,默认是1(可以省略不写)
• 步长不能是0,但可以是是负数-->可也做成倒序,达到list.reverse()或者sort(key=None,reverse=False)效果
3. 通用操作
• + 和 *
• + 可以将两个列表拼接成一个列表
• * 可以将列表重复指定的次数 (注意2个列表不能够做乘法,要和整数做乘法运算)
lst = [1,2,3] + [4,5,6]
lst = [4,5,6] * [1,2,3] # TypeError: can't multiply sequence by non-int of type 'list'
• in 和 not in
• in用来检查指定元素是否在列表当中
• not in 用来检查指定元素是否不在列表当中
hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长']
print('钢铁侠'not in hero)
#False
• **len() **获取列表中元素的个数 *是列表的最大索引值+1
hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长']
print(hero[len(hero)-1])
#美国队长
• max() 获取列表中最大值
• min() 获取列表中最小值
方法和函数的区别
- 方法必须通过** 对象.方法() **
方法:xxx.yyy()
函数:zzz()
• list.index(x[, start[, end]])(也是获取第一个)
第一个参数 获取指定元素在列表中的位置
第二个参数 表示查找的起始位置
第三个参数 表示查找的结束位置
hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长','蜘蛛侠','蜘蛛侠']
print(hero.index('蜘蛛侠',3,7))
#6
print(hero.index('蜘蛛侠')
#2
• list.count(x) 统计指定元素在列表中出现的个数
hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长','蜘蛛侠','蜘蛛侠']
print(hero.count('蝙蝠侠'))
#0
4. 修改列表
• 通过切片来修改(起始就是给切片的内容重新赋值,但是赋值的内容必须是一个序列)
hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长']
hero[0:2] = 123 # TypeError: can only assign an iterable
hero[0:3] = 'abcd'
print('修改后',hero)
#修改后 ['a', 'b', 'c', 'd', '黑寡妇', '蚁人', '美国队长']
• 当设置了步长时,序列中元素的个数必须和切片中元素的个数保持一致
hero[::2] = ['黑豹'] * 3
print('修改后',hero)
#修改后 ['黑豹', '绿巨人', '黑豹', '黑寡妇', '黑豹', '美国队长']
• 通过切片来删除元素
hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','蚁人','美国队长']
hero[1:3] = []
print('修改后',hero)
#修改后 ['钢铁侠', '黑寡妇', '蚁人', '美国队长']
• del list[起始 : 结束]
• list = [] *不可变序列无法通过索引修改,可通过转为列表修改。
s = 'python'
s[1] = 'j' #TypeError: 'str' object does not support item assignment
s = list(s)
s[1] = 'j'
print(s)
#['p', 'j', 't', 'h', 'o', 'n']
5. 列表的方法
• append() 向列表的最后添加一个元素
• insert(arg1,arg2) 向列表指定位置插入**一个元素
参数1:要插入的位置 参数2:要插入的元素
hero = ['钢铁侠','绿巨人','蜘蛛侠']
hero.insert(2,'黑寡妇')
print(hero) #['钢铁侠', '绿巨人', '黑寡妇', '蜘蛛侠']
• extend(iterable) 使用一个新的序列来扩展当前序列(它会将该序列的中元素添加到列表中) 参数需要传递一个序列。和+的作用一样
hero = ['钢铁侠','绿巨人','蜘蛛侠']
hero.extend(123) TypeError: 'int' object is not iterable
hero.extend(['黑寡妇','蚁人'])
hero += ['黑寡妇','蚁人']
• pop() 根据索引删除并返回指定元素
hero = ['钢铁侠','绿巨人','蜘蛛侠']
result = hero.pop(2)
print('result = ',result) #result = 蜘蛛侠
hero.pop() # 如果不穿索引值就删除最后一个元素
• remove() 删除指定元素 (如果相同值的元素有多个,只会删除第一个)
• **reverse() **翻转列表
hero.reverse()
• sort(key=None,reverse=False) 用来对列表中的元素进行排序 reverse:True反序;False 正序
lst = list('asnbdnbasdab')
print('修改前',lst)
lst.sort(reverse=True)
print('修改后',lst)
6. 遍历列表
6.1 for循环
• 通过for循环来遍历列表
语法
for 变量 in 序列(遍历的规则):
代码块
• 注意: for循环的代码块会执行多次,序列中有几个元素就会执行几次。每执行一次就会将序列中的一个元素赋值给变量,所以我们可以通过变量来获取列表中的元素。
例子:一样的效果,while需要自定义长度(为后续维护方便-->当列表更新时,后续操作应能自动更新)
#创建一个循环 打印0-3
hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','灭霸']
# 遍历列表 指的就是将列表当中的元素提取出来
print(hero[0])
print(hero[1])
print(hero[2])
print(hero[3])
#while
i = 0
while i < len(hero):
print(hero[i])
i += 1
#for
for s in hero:
print(s)
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)
lit = [1,2,3,4,5,6,7,8,9]
# 获取列表当中的奇数
for i in range(0,9,2):
print(lit[i])
#解析:
索引i=range(0,9,2)=0,2,4,8
对应在lit中的数值时1,3,5,7,9