Python序列的推导式实现代码
作者:繁华似锦Fighting 发布时间:2022-04-24 05:53:46
推导式comprehensions
(又称解析式),是Python的一种独有特性。
推导式是可以从一个数据序列构建另一个新的数据序列(的一种结构体)。
Python中共有三种推导,在Python2和3中都有支持:
列表推导式
字典推导式
集合推导式
1、列表推导式
作用:用一个表达式创建一个有规律的列表或控制一个有规律列表。
列表推导式又叫列表生成式。
(1)快速体验
需求:创建一个0-10的列表。
while
循环实现
# 1. 准备一个空列表
list1 = []
# 2. 书写循环,依次追加数字到空列表list1中
i = 0
while i < 10:
list1.append(i)
i += 1
# 结果:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
print(list1)
for
循环实现
list1 = []
for i in range(10):
list1.append(i)
# 结果:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
print(list1)
列表推导式实现
"""
因为是列表推导式,所以等号右边的表达式要用[]括起来
因为最终要返回一个列表。
在推导式中,读与写都从for循环开始,
for的左侧是一个返回值,一次for循环返回的数值。
for每一次遍历,都向列表中添加一个i变量。
"""
# 结果:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
list1 = [i for i in range(10)]
print(list1)
列表推导式就是化简代码,创建或控制有规律的列表。
(2)带if的列表推导式
需求:创建0-10的偶数列表
方法一:通过range()
步长实现
# 结果:[0, 2, 4, 6, 8]
list1 = [i for i in range(0, 10, 2)]
print(list1)
方法二:通过if
实现
# 1. for循环加if 创建有规律的列表
list2 = []
for i in range(10):
if i % 2 == 0:
list2.append(i)
# 结果:[0, 2, 4, 6, 8]
print(list2)
# 2.把for循环配合if的代码 改写 带if的列表推导式
list1 = [i for i in range(10) if i % 2 == 0]
# 结果:[0, 2, 4, 6, 8]
print(list1)
(3)多个for循环实现列表推导式
需求,创建列表如下:
[(1, 0), (1, 1), (1, 2), (2, 0), (2, 1), (2, 2)]
代码如下:
list1 = [(i, j) for i in range(1, 3) for j in range(3)]
print(list1)
# 推导过程如下
# 多for的列表推导式等同于for循环嵌套
# [(1, 0), (1, 1), (1, 2), (2, 0), (2, 1), (2, 2)]
# 数据1 : 1 和 2 range(1,3)
# 数据2 :0 1 2 range(3)
list1 = []
for i in range(1, 3):
for j in range(3):
# 列表里面追加元组: 循环前准备一个空列表,
# 然后这里追加元组数据到列表
list1.append((i, j))
print(list1)
# 多个for实现列表推导式
list2 = [(i, j) for i in range(1, 3) for j in range(3)]
print(list2)
2、字典推导式
思考:如果有如下两个列表:
list1 = ['name', 'age', 'gender']
list2 = ['Tom', 20, 'man']
如何快速合并为一个字典?
答:用for
循环拼接可以实现,但是我们可以通过改写for
循环,变成一个字典推导式。
字典推导式作用:快速合并列表为字典或提取字典中目标数据。
通过下面示例快速体验字典推导式。
(1)创建一个字典
字典key
是1-5数字,value
是这个数字的2次方。
# dict1 = {k: v for i in range(1, 5)}
dict1 = {i: i**2 for i in range(1, 5)}
print(dict1) # {1: 1, 2: 4, 3: 9, 4: 16}
{i:i**2}
表示的是一个字典,key
是i
,value
是i**2
。
最后要返回一个字典,所以右边表达式的最外层是一个大括号。
(2)将两个列表合并为一个字典
list1 = ['name', 'age', 'gender']
list2 = ['Tom', 20, 'man']
dict1 = {list1[i]: list2[i] for i in range(len(list1))}
print(dict1)
# 结果:{'name': 'Tom', 'age': 20, 'gender': 'man'}
总结:
如果两个列表数据个数相同,
len
统计任何一个列表的长度都可以。如果两个列表数据个数不同,
len
统计数据多的列表数据个数会报错;len
统计数据少的列表数据个数不会报错。(这点一定要注意)
(3)提取字典中目标数据
counts = {'MBP': 268, 'HP': 125, 'DELL': 201, 'Lenovo': 199, 'acer': 99}
# 需求:提取上述电脑数量大于等于200的字典数据
count1 = {key: value for key, value in counts.items() if value >= 200}
print(count1) # {'MBP': 268, 'DELL': 201}
3、集合推导式
集合推导式比上面两个推导式使用的频率要少很多。
需求:创建一个集合,数据为下方列表的2次方。
list1 = [1, 1, 2]
代码如下:
list1 = [1, 1, 2]
set1 = {i ** 2 for i in list1}
print(set1) # {1, 4}
注意:集合有数据去重功能。
4、补充提示
我们如何查看Python中关于序列的相关文档:
打开文件找到序列部分文档
[The Python Standard Library(Python标准库)] —> 右边页面[Sequence Type]
Common Sequence Operations
下的列表为序列的通用操作。就是可变序列和不可变序列都可以用的方法或者函数。
Mutable Sequence Types
下的列表为可变序列可以用的方法或者函数。
来源:https://www.cnblogs.com/liuyuelinfighting/p/14993281.html


猜你喜欢
- 在做js测试的时候用到了startsWith函数,但是他并不是每个浏览器都有的,所以我们一般要重写一下这个函数,具体的用法可以稍微总结一下在
- 使用微信获取地址信息是和微信支付一道申请的,微信支付申请通过,就可以使用该功能。微信商城中,使用微信支付获取用户的收货地址,可以省略用户输入
- 方法组成模式方法里的所有语句都必须处在同一个归纳层次上无用的注释让代码自我表白标注为什么这样,而不是如何这样对方法表现进行描述等于重复表现这
- 故障表现一方面 :在阿里云控制台云数据库PolarDB对应的集群管理页面上,在诊断与优化模块里面的一键诊断会话管理中,发现某条update
- Python中,列表是可以进行修改的:赋值、删除元素、分片等等。在给列表添加元素时,有两个常见的方法:append和extend。appen
- 首先看下面的代码创建存储过程1、创建存储过程,语句如下: CREATE PROC P_viewPage @TableName VARCHAR
- 背景我们先来看看MySQL 8.0的事务提交的大致流程以上流程,是MySQL8.0对WAL原则的一种实现,这个流程意味着,任何一个事务的提交
- 1.打包项目期间遇到的坑,提前说下,避免重复工作。1.1打包的app出现白屏。出现原因:路径不对,需要改config\index.js解决办
- np.percentilenumpy.percentile(a, q, axis=None, out=None, overwrite_inp
- 发现问题最近在工作中遇到一个问题,MySQL数据库建表的时候采用的是latin的字符集,而网页中查询的是utf-8,当输入页面输入中文,然后
- Python具有基本的文本文件读写功能。Python的标准库提供有更丰富的读写功能。文本文件的读写主要通过open()所构建的文件对象来实现
- SQL中的单记录函数 1.ASCII 返回与指定的字符对应的十进制数; SQL> select ascii('A')
- <% '#######以下是一个类文件,下面的注解是调用类的方法#########################
- 调试程序的过程中,发现通过os.path.join拼接的路径出现了反斜杠directory1='/opt/apps/upgradeP
- 1.计算变量缺失率df=pd.read_csv('titanic_train.csv')def missing_cal(df
- 冒泡的表现近期用vue做了一个需求,大概是同一个区域,点击不同位置有不同的响应函数,还有个总的响应函数,好吧,如下图所示:他们的DOM结构如
- 思维导图:效果(语句版):源码:# -*- coding: utf-8 -*-"""Created
- 图片文字分割的时候,常用的方法有两种。一种是投影法,适用于排版工整,字间距行间距比较宽裕的图像;还有一种是用OpenCV的轮廓检测,适用于文
- Python OpenCV存储图像使用的是Numpy存储,所以可以将Numpy当做图像类型操作,操作之前还需进行类型转换,转换到int8类型
- SQL Server UPDATE语句用于更新数据,下面就为您详细介绍SQL Server UPDATE语句语法方面的知识,希望可以让您对S