Python序列的公共API指的就是,之前所学过的Python序列,如:列表、元组、字典等,基本上都支持的操作。

总结如下:

1、运算符

运算符 描述 支持的容器类型
+ 合并 字符串、列表、元组
* 复制 字符串、列表、元组
in 元素是否存在 字符串、列表、元组、字典
not in 元素是否不存在 字符串、列表、元组、字典

@1、+加号

+可以将两个序列拼接为一个序列。

# 1. 字符串 `+`号
str1 = 'aa'
str2 = 'bb'
str3 = str1 + str2
print(str3) # aabb # 2. 列表 `+`号
list1 = [1, 2]
list2 = [10, 20]
list3 = list1 + list2
print(list3) # [1, 2, 10, 20] # 3. 元组 `+`号
t1 = (100, 200)
t2 = (10, 20)
t3 = t1 + t2
print(t3) # (100, 200, 10, 20) # 4.字典 `+`号
# 结果:TypeError: unsupported operand type(s) for +: 'dict' and 'dict'
dict1 = {'name': 'Python'}
dict2 = {'age': 30}
dict3 = dict1 + dict2
print(dict3) # 异常

@2、*乘号

可以将序列重复指定的次数。

# 1. 字符串
# 结果:----------
print('-' * 10) # 2. 列表
# 结果:['hello', 'hello', 'hello', 'hello']
list1 = ['hello']
print(list1 * 4) # 3. 元组
# 结果:('world', 'world', 'world', 'world')
t1 = ('world',)
print(t1 * 4) # 字典
# 结果:TypeError: unsupported operand type(s) for *: 'dict' and 'int'
dict1 = {'name': 'Python'}
print(dict1 * 4) # 异常

@3、innot in

# 1. 字符串
print('a' in 'abcd') # True
print('a' in 'hijk') # False
print('a' not in 'abcd') # False
print('a' not in 'hijk') # True # 2. 列表
list1 = ['a', 'b', 'c', 'd']
list2 = ['h', 'i', 'j', 'k']
print('a' in list1) # True
print('a' in list2) # False
print('a' not in list1) # False
print('a' not in list2) # True # 3. 元组
t1 = ('a', 'b', 'c', 'd')
t2 = ('i', 'j', 'h', 'k')
print('a' in t1) # True
print('a' in t2) # False
print('a' not in t1) # False
print('a' not in t2) # True # 4. 字典
dict1 = {'name': 'Python', 'age': 30}
print('name' in dict1) # True
print('name' not in dict1) # False
print('name' in dict1.keys()) # True
print('name' in dict1.values()) # False

2、公共方法

函数 描述
len() 计算容器中元素个数
deldel() 删除
max() 返回容器中元素最大值
min() 返回容器中元素最小值
range(start, end, step) 生成从start到end的数字,步长为 step,供for循环使用
enumerate() 函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,同时列出数据和数据下标,一般用在 for 循环当中。

@1、len()方法

# 1. 字符串
str1 = 'abcdefg'
print(len(str1)) # 7 # 2. 列表
list1 = [10, 20, 30, 40]
print(len(list1)) # 4 # 3. 元组
t1 = (10, 20, 30, 40, 50)
print(len(t1)) # 5 # 4. 集合
s1 = {10, 20, 30}
print(len(s1)) # 3 # 5. 字典
dict1 = {'name': 'Rose', 'age': 18}
print(len(dict1)) # 2

@2、deldel()

# del和del()都能删除一个序列对象,
# 也能删除序列中的一个元素 # 1. 字符串
# 不同通过del(str1[0])或del str1[0],删除字符串中的字符。
# 结果:NameError: name 'str1' is not defined
str1 = 'abcdefg'
# del(str1)
del str1
print(str1) # 2. 列表(元组同理)
list1 = [10, 20, 30, 40]
# 删除列表中的某一元素
# del(list1[0])
del list1[0]
print(list1) # [20, 30, 40] # 删除列表
# del(list1)
del list1 # 3.字典
dict1 = {'name': 'TOM', 'age': 18}
# 删除字典中的某一元素
# del(dict1['name'])
del dict1['name'] # 删除字典
# del(dict1)
del dict1

@3、max()方法

# 返回容器中元素最大值
# 1. 字符串
str1 = 'abcdefg'
print(max(str1)) # g # 2. 列表
list1 = [10, 20, 30, 40]
print(max(list1)) # 40

@4、min()方法

# 返回容器中元素最小值
# 1. 字符串
str1 = 'abcdefg'
print(min(str1)) # a # 2. 列表
list1 = [10, 20, 30, 40]
print(min(list1)) # 10

@5、range()

range()是一个函数,可以用来生成一个可迭代的自然数的序列。

语法

range(start, end, step)

生成从startend的数字,前闭后开。

步长为step,步长可以省略,默认为1,

range()函数和切片使用方式同理,包括步长可以是负数,

步长要和数字升降的方向一致。

示例

# range(start, end, step)

# 1 2 3 4 5 6 7 8 9
for i in range(1, 10, 1):
print(i, end=' ') # 1 3 5 7 9
for i in range(1, 10, 2):
print(i, end=' ') # 1. 如果不写开始,默认从0开始
# 2. 如果不写步长,默认为1
# 0 1 2 3 4 5 6 7 8 9
for i in range(10):
print(i, end=' ') """
range(0, 10, -1),中0到10是递增的,而-1是反向选取,
方向相反所以不能取到值。 (10, 0, -1),10到0是递减的,-1是反向选取
方向相同,生成的序列中就有值。 同切片中的示例。
"""
# 1.正确
# 结果:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
r = range(0, 10, 1) # 正确
print(list(r)) # 2.range(0, 10, -1)没有创建的序列中没有元素
# 结果:[]
r1 = range(0, 10, -1) # 错误
print(list(r1)) # 3.正确
# 结果:[10, 9, 8, 7, 6, 5, 4, 3, 2, 1]
r2 = range(10, 0, -1) # 正确
print(list(r2))

注意:range()函数一般情况下都和for循环配合使用,可以创建一个执行指定次数的for循环。

例如:

for i in range(10):
print(i)

@6、enumerate()

enumerate()函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,同时列出数据和数据下标,一般用在for循环当中。

语法

enumerate(可遍历对象, start=0)

注意:start参数用来设置遍历数据的下标的起始值,默认为0。

快速体验

list1 = ['a', 'b', 'c', 'd', 'e']

for i in enumerate(list1):
print(i) for index, char in enumerate(list1, start=1):
print(f'下标是{index}, 对应的字符是{char}') """
输出结果:
(0, 'a')
(1, 'b')
(2, 'c')
(3, 'd')
(4, 'e')
下标是1, 对应的字符是a
下标是2, 对应的字符是b
下标是3, 对应的字符是c
下标是4, 对应的字符是d
下标是5, 对应的字符是e
"""

3、容器类型转换

@1、tuple()函数

作用:将某个序列转换成元组

list1 = [10, 20, 30, 40, 50, 20] # 列表
s1 = {100, 200, 300, 400, 500} # 集合 """
输出结果:
(10, 20, 30, 40, 50, 20)
(100, 200, 300, 400, 500)
"""
print(tuple(list1))
print(tuple(s1))

@2、list()函数

作用:将某个序列转换成列表

t1 = ('a', 'b', 'c', 'd', 'e') # 元组
s1 = {100, 200, 300, 400, 500} # 集合 """
输出结果:
['a', 'b', 'c', 'd', 'e']
[100, 200, 300, 400, 500]
"""
print(list(t1))
print(list(s1))

@3、set()函数

作用:将某个序列转换成集合

list1 = [10, 20, 30, 40, 50, 20] # 列表
t1 = ('a', 'b', 'c', 'd', 'e') # 元组 """
输出结果:
{40, 10, 50, 20, 30}
{'c', 'd', 'e', 'a', 'b'}
"""
print(set(list1))
print(set(t1))

注意:

  1. 集合可以快速完成列表去重。
  2. 集合不支持下标。

『无为则无心』Python序列 — 23、Python序列的公共API的更多相关文章

  1. 『无为则无心』Python基础 — 16、Python序列之字符串的下标和切片

    目录 1.序列的概念 2.字符串的下标说明 3.字符串的切片说明 1.序列的概念 序列sequence是Python中最基本的数据结构.指的是一块可存放多个值的连续内存空间,这些值按一定顺序排列,可通 ...

  2. 『无为则无心』Python序列 — 20、Python元组的介绍与使用

    目录 1.元组的应用场景 2.定义元组 3.元组的常见操作 @1.按下标查找数据 @2.index()方法 @3.count()方法 @4.len()方法 4.元祖中的列表元素 5.扩展:序列封包和序 ...

  3. 『无为则无心』Python序列 — 24、Python序列的推导式

    目录 1.列表推导式 (1)快速体验 (2)带if的列表推导式 (3)多个for循环实现列表推导式 2.字典推导式 (1)创建一个字典 (2)将两个列表合并为一个字典 (3)提取字典中目标数据 3.集 ...

  4. 『无为则无心』Python基础 — 12、Python运算符详细介绍

    目录 1.表达式介绍 2.运算符 (1)运算符的分类 (2)算数运算符 (3)赋值运算符 (4)复合赋值运算符 (5)比较运算符 3.逻辑运算符 拓展1:数字之间的逻辑运算 拓展2:Python中逻辑 ...

  5. 『无为则无心』Python基础 — 61、Python中的迭代器

    目录 1.迭代的概念 2.迭代器的概念 3.可迭代的对象(Iterable) 4.迭代器对象(Iterator) 5.迭代器的使用体验 (1)基本用法 (2)实际应用 1.迭代的概念 (1)什么是迭代 ...

  6. 『无为则无心』Python基础 — 4、Python代码常用调试工具

    目录 1.Python的交互模式 2.IDLE工具使用说明 3.Sublime3工具的安装与配置 (1)Sublime3的安装 (2)Sublime3的配置 4.使用Sublime编写并调试Pytho ...

  7. 『无为则无心』Python基础 — 6、Python的注释

    目录 1.注释的作用 2.注释的分类 单行注释 多行注释 3.注释的注意事项 4.什么时候需要使用注释 5.总结 提示:完成了前面的准备工作,之后的文章开始介绍Python的基本语法了. Python ...

  8. 『无为则无心』Python基础 — 7、Python的变量

    目录 1.变量的定义 2.Python变量说明 3.Python中定义变量 (1)定义语法 (2)标识符定义规则 (3)内置关键字 (4)标识符命名习惯 4.使用变量 1.变量的定义 程序中,数据都是 ...

  9. 『无为则无心』Python基础 — 10、Python字符串的格式化输出

    目录 1.什么是格式化输出 2.Python格式化输出的五种方式 方式一:字符串之间用+号拼接 方式二:print()函数可同时输出多个字符串 方式三:占位符方式 方式四:f格式化方式(推荐) 方式五 ...

随机推荐

  1. [刷题] PTA 6-7 统计某类完全平方数

    要求: 实现一个函数,判断任一给定整数N是否满足条件:它是完全平方数,又至少有两位数字相同,如144.676等. 函数接口定义: int IsTheNumber ( const int N ); 其中 ...

  2. Linux查看登录日志 last命令 查看当前登录用户

    Linux查看登录日志 linux 发布于 31 分钟前   lastlog 打印系统账号最近一次的登录记录情况,解析的是/var/log/lastlog文件,它是一个data file类型的文件,文 ...

  3. cento 7使用minicom串口调试工具

    cento 7使用minicom串口调试工具   因为要使用串口配置设备,所以考虑要用串口管理软件,windows下比较容易了,直接用超级终端也好,用CRT也可以,CentOS系统稍微麻烦一点,前几天 ...

  4. Jenkins远程代码执行漏洞

    于一个月前,进行服务器巡检时,发现服务器存在不明进程,并且以Jenkins用户身份来运行.当时进行了处理并修复了漏洞.在此补上修复过程 第一反应是Jenkins存在漏洞,于是Google Jenkin ...

  5. 关于Python闭包的一切

    任何把函数当做一等对象的语言,它的设计者都要面对一个问题:作为一等对象的函数在某个作用域中定义,但是可能会在其他作用域中调用,如何处理自由变量? 自由变量(free variable),未在局部作用域 ...

  6. 西门子 S7-200 通过以太网通讯模块连接MCGS 通讯

    北京华科远创科技有限研发的远创智控ETH-YC模块,以太网通讯模块型号有MPI-ETH-YC01和PPI-ETH-YC01,适用于西门子S7-200/S7-300/S7-400.SMART S7-20 ...

  7. JavaSE-QuickStart

    老话常说:基础不牢地动山摇,于是我在b站上看杨中科老师的课程脑补一下,便记录这岁月的点滴 1.什么是编程 ? 编程:编写能够控制计算机来执行特定任务的代码. 2.什么是编程语言 ? 编程语言:是指程序 ...

  8. Step By Step(Lua模块与包)

    Step By Step(Lua模块与包) 从Lua 5.1开始,我们可以使用require和module函数来获取和创建Lua中的模块.从使用者的角度来看,一个模块就是一个程序库,可以通过requi ...

  9. Jmeter- 笔记3 - Jmeter录制功能 / 抓包

    http代理服务器录制脚本: 1.新建线程组 2.添加 http代理服务器 元件 3.http代理服务器修改: 1)端口:8899,任意给个无占用的 2)目标控制器:改成刚刚新建的线程组.不改就录制会 ...

  10. sql server 操作(不定期更新)

    要求:基本的语法要清楚. sql server疑难点: 1.Partition by可以理解为 对多行数据分组后排序取每个产品的第一行数据 先处理内查询,由内向外处理,外层查询利用内层查询的结果嵌套查 ...