Python 序列类型

简介: 在程序设计中,经常会遇到要处理很多相同类型的数据的情况,比如统计全班同学的分数、统计每篇博客的浏览量、统计每种商品的单价等等。这时如果用一个变量存储一个数据,难免有些不便。Python 中的序列类型就能很好地解决这些问题。序列类型是组合数据类型的一类,能够将多个同类型或不同类型的数据组织起来,通过单一的表示使数据操作更有序更容易。序列类型是一个元素向量,元素之间存在先后关系,通过序号访问,元素之间不排他。字符串(str):由按照一定顺序组合在一起的字符来构成的,如:'Python'列表(list。

✅作者简介:人工智能专业本科在读,喜欢计算机与编程,写博客记录自己的学习历程。
🍎个人主页:小嗷犬的博客
🍊个人信条:为天地立心,为生民立命,为往圣继绝学,为万世开太平。
🥭本文内容:Python 序列类型
更多内容请见👇


@TOC

1.什么是序列类型

在程序设计中,经常会遇到要处理很多相同类型的数据的情况,比如统计全班同学的分数、统计每篇博客的浏览量、统计每种商品的单价等等。这时如果用一个变量存储一个数据,难免有些不便。Python 中的序列类型就能很好地解决这些问题。

序列类型是组合数据类型的一类,能够将多个同类型或不同类型的数据组织起来,通过单一的表示使数据操作更有序更容易。

序列类型是一个元素向量,元素之间存在先后关系,通过序号访问,元素之间不排他

Python中的主要序列类型:

  • 字符串(str):由按照一定顺序组合在一起的字符来构成的,如:
'Python'
  • 列表(list):包含0个或多个不同类型元素的可变序列类型,用方括号将元素包含在一起,如:
['Python', 1, 3.14, [2, 2.71], '555']
  • 元组(tuple):包含0个或多个不同类型元素的不可变序列类型,用圆括号将元素包含在一起,如:
('Python', 1, 3.14, (2, 2.71), '555')

2.通用序列类型操作

所有序列类型都可以进行一些特定的操作,包括索引、切片、连接、重复、成员资格检查、计算元素出现次数等。

2.1 索引

序列类型是一个元素向量,元素之间存在先后关系,所有元素都有序号(有时也称为偏移量或索引),序列中的元素可以通过序号进行访问,通过序号获取序列中特定位置的元素,就是索引:
l = ['Python', 1, 3.14, [2, 2.71], '555']
print(l[2])
除了可以从左往右地从 0开始索引,也可以从右往左由 -1开始索引,也可以混合使用:
l = ['Python', 1, 3.14, [2, 2.71], '555']
print(l[-2][1])
同时要注意,索引不能 越界

2.2 切片

在使用序列类型数据的过程中,常常会遇到需要获取其中一部分数据的情况。这时,可以使用分片,它是索引的一种扩展方式,返回的是序列类型数据中的一个片段,而不是一个单独的元素。

切片的语法格式为:

<字符串>[<左边界>:<右边界>:<步长>]

对于切片,有以下一些需要注意的地方,以字符串'Python'为例:

  • 包含左边界,不包含右边界。
  • s[:] 获得包含所有字符的新字符串,缺省的左边界为 0,右边界为序列长度。
  • s[0:2] 获得新字符串“Py”,即序号为 0 直到序号为 2 之前的所有字符。
  • s[2:] 获得新字符串“thon”,即从序号 2 到最后的所有字符。
  • s[:3] 获得新字符串“Pyt”,即从开头直到不包括序号为 3 之间的所有字符。
  • s[:-1] 获得新字符串“Python”,即从开头直到不包括最后一个字符之间 的所有字符。

2.2.1 步长

在切片时,除了可以指定左边界和右边界的序号外(或者不指定而使用缺省值),还可以增加第三个值,即步长。

步长用于规定切片的间隔:

s = '我是小嗷犬嗷嗷嗷'
print(s[1:6:2])
步长也可以是负数,即以相反的顺序来获取元素:
s = '我是小嗷犬嗷嗷嗷'
print(s[::-1])

2.3 连接和复制

+操作符可以连接两个类型相同的序列,得到一个新的该类型序列,就像它将两个字符串合并成一个新字符串一样:
s = '我是小嗷犬' + '嗷嗷嗷'
print(s)
*操作符也可以用于其他的序列类型,序列类型的值和一个整数 n相乘,得到将该序列类型值重复 n次的新的对象:
s = '我是小嗷犬' * 3
print(s)

2.4 in 和 not in

通过运算符 in可以判断某个元素是否在序列中,如果元素在序列中, in表达式返回 True,否则返回 False。运算符 not in则正好相反:
email = '123456@qq.com'
print('@qq.com' in email)

2.5 count()

当需要计算某个元素在序列中出现的次数时,使用序列的 count()方法可以很轻松的完成这个任务:
fruits = ['apple', 'banana', 'apple', 'orange', 'apple', 'banana']
print(fruits.count('apple'))

2.6 序列类型通用操作符和函数

序列类型有12个通用的操作符和函数:
操作符 描述
x in s 如果x是s的元素,返回True,否则返回False
x not in s 如果x不是s的元素,返回True,否则返回False
s + t 连接s和t
s * nn * s 将序列s复制n次
s[i] 索引,返回序列的第i个元素
s[i: j] 切片,返回包含序列s第i到j个元素的子序列(不包含第j个元素)
s[i: j: k] 步骤切片,返回包含序列s第i到j个元素以j为步数的子序列
len(s) 序列s的元素个数(长度)
min(s) 序列s中的最小元素
max(s) 序列s中的最大元素
s.index(x[, i[, j]]) 序列s中从i开始到j位置中第一次出现元素x的位置
s.count(x) 序列s中出现x的总次数
目录
相关文章
|
5小时前
|
机器学习/深度学习 运维 Python
python深度学习实现自编码器Autoencoder神经网络异常检测心电图ECG时间序列
python深度学习实现自编码器Autoencoder神经网络异常检测心电图ECG时间序列
|
5小时前
|
Python
在Python中,全局变量和局部变量是两种不同类型的变量
【5月更文挑战第10天】Python中的全局变量在函数外部定义,作用域覆盖整个程序,生命周期从开始到结束。局部变量仅限于函数内部,生命周期从调用到返回。在函数内修改全局变量需用`global`关键字声明,否则会创建局部变量。
18 3
|
5小时前
|
数据可视化 数据挖掘 Python
Python时间序列分析苹果股票数据:分解、平稳性检验、滤波器、滑动窗口平滑、移动平均、可视化(下)
Python时间序列分析苹果股票数据:分解、平稳性检验、滤波器、滑动窗口平滑、移动平均、可视化
|
5小时前
|
数据可视化 API 开发者
Python时间序列分析苹果股票数据:分解、平稳性检验、滤波器、滑动窗口平滑、移动平均、可视化(上)
Python时间序列分析苹果股票数据:分解、平稳性检验、滤波器、滑动窗口平滑、移动平均、可视化
|
5小时前
|
Python
Python使用类型注解
【5月更文挑战第7天】
8 2
|
5小时前
|
索引 Python
【Python操作基础】——序列
【Python操作基础】——序列
|
5小时前
|
JSON 数据格式 Python
Python 的 requests 库是一个强大的 HTTP 客户端库,用于发送各种类型的 HTTP 请求
【5月更文挑战第9天】`requests` 库是 Python 中用于HTTP请求的强大工具。要开始使用,需通过 `pip install requests` 进行安装。发送GET请求可使用 `requests.get(url)`,而POST请求则需结合 `json.dumps(data)` 以JSON格式发送数据。PUT和DELETE请求类似,分别调用 `requests.put()` 和 `requests.delete()`。
17 2
|
5小时前
|
Java C# 开发者
Python 中的类型注解是一种用于描述变量、函数参数和返回值预期类型的机制
【5月更文挑战第8天】Python的类型注解提升代码可读性和可维护性,虽非强制,但利于静态类型检查(如Mypy)。包括:变量注解、函数参数和返回值注解,使用内置或`typing`模块的复杂类型,自定义类型注解,以及泛型模拟。类型注解可在变量声明、函数定义和注释中使用,帮助避免类型错误,提高开发效率。
19 6
|
5小时前
|
数据处理 Python
Python中的数字类型
【5月更文挑战第6天】Python数字类型:无限制大小的整型(int,包括二、八、十、十六进制),浮点型(float,支持科学记数法),布尔型(bool,True/False),和复数型(complex,如a+bi)。用于数值计算和数据处理。
16 0
|
5小时前
|
索引 Python
python类型错误(TypeError)
【5月更文挑战第1天】
45 2