Python-序列

1. 序列(sequence)

1.1基本概念

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

1.2序列的分类

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

2. 列表(list)

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

2.1列表的创建

通过[]来创建一个空列表
一个列表当中可以存储多个元素,也可以在创建列表的时候,指定列表当中的元素
当列表当中添加多个元素要用 , 隔开
列表可以存储任意对象
lst = [1,‘python’,None,True,[1,2,3]]
索引
序列中,每个元素都有属于自己的编号(索引)。从起始元素开始,索引值从 0 开始递增,如图 1 所示。在这里插入图片描述

除此之外,Python 还支持索引值是负数,此类索引是从右向左计数,换句话说,从最后一个元素开始计数,从索引值 -1 开始,如图 2 所示。在这里插入图片描述
print(lst[-1])
print(lst[-2])
注意,在使用负值作为列序中各元素的索引值时,是从 -1 开始,而不是从 0 开始。
无论是采用正索引值,还是负索引值,都可以访问序列中的任何元素。

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) 使用一个新的序列来扩展当前序列(它会将该序列的中元素添加到列表中) 参数需要传递一个序列
clear() 清空列表
count()统计列表中某个对象的个数
copy()拷贝列表
pop() 根据索引删除并返回指定元素
remove() 删除指定元素 (如果相同值的元素有多个,只会删除第一个)
reverse() 翻转列表
sort(key=None,reverse=False) 用来对列表中的元素进行排序
reverse:True反序;False 正序

hero = ['钢铁侠','绿巨人','蜘蛛侠','绿巨人']
print(hero.copy())
hero[2] = 'b'
print(hero)
hero.append('黑寡妇')
print(hero)
hero.count('钢铁侠')
hero.extend(['马云','胡歌'])
print(hero)
k=hero.pop(2)
print(k)
print(hero)
hero.remove('绿巨人')
print(hero)
hero.reverse()
print(hero)
hero.sort(reverse=False)
print(hero)

结果:

['钢铁侠', '绿巨人', '蜘蛛侠', '绿巨人']
['钢铁侠', '绿巨人', 'b', '绿巨人']
['钢铁侠', '绿巨人', 'b', '绿巨人', '黑寡妇']
1
['钢铁侠', '绿巨人', 'b', '绿巨人', '黑寡妇', '马云', '胡歌']
b
['钢铁侠', '绿巨人', '绿巨人', '黑寡妇', '马云', '胡歌']
['钢铁侠', '绿巨人', '黑寡妇', '马云', '胡歌']
['胡歌', '马云', '黑寡妇', '绿巨人', '钢铁侠']
['绿巨人', '胡歌', '钢铁侠', '马云', '黑寡妇']

6. 遍历列表

6.1 for循环

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

hero = ['钢铁侠','绿巨人','蜘蛛侠','黑寡妇','灭霸']
print(hero[0])
print(hero[1])
print(hero[2])
print(hero[3])
#方法二:
i = 0
while i < len(hero):
    print(hero[i])
    i += 1
#方法三:
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=[0,1,2,3,4,5,6,7,8,9]
for i in range(1,10,2):
    print(lit[i])

结果:

1
3
5
7
9
lit=[0,1,2,3,4,5,6,7,8,9]
for i in range(0,9,2):
    print(lit[i])

结果:

0
2
4
6
8

综合案例:

#现在有 a = [1,2,3,4,5,6] 不通过函数的形式实现列表的反转([6,5,4,3,2,1]) 并写出推导过程
#方法一:
 a=[1,2,3,4,5,6]
 b=[]
 b=a[::-1]
 print(b)
#方法二:
 a = [1,2,3,4,5,6]
 a.reverse()
 print(a)
#方法三:
 a= [1,2,3,4,5,6]
 a.sort(reverse=True)
 print(a)
#方法四:
a = [1,2,3,4,5,6]
 d = len(a)
 b=[1,2,3,4,5,6]
 i = 0
 while i < d:
     b[i] = a[d-i-1]
    #print(b[i])
     i += 1
 print(b)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值