Python推导式使用详情

目录
  • 推导式
    • 什么是推导式
    • 基本语法
    • 其它使用方法
  • 列表推导式练习题
  • 集合推导式
  • 字典推导式
    • 字典推导式常用以配合的函数
  • enumerate
  • zip
  • 优先使用推导式

推导式

什么是推导式

推导式是 for 循环的简化使用方法,使用推导式,将一个可迭代对象中的数据遍历到某一个容器当中。简单的来说就是用一行for循环语句,遍历一个可迭代对象中的所有数据,然后将遍历出来的数据进行处理放入对应的容器中的一个过程和方式。

和推导类似作用的还有三元运算符,三元运算符是条件判断语句的简化使用方法。

语法:

val for val in Iterable

就是存入容器中的数据for循环语句

推导式有三种表达方式,分别用对应的符号包裹推导式语句:

  • 列表推导试:[val for val in Iterable]
  • 集合推导式:{val for val in Iterable}
  • 字典推导式:{x,y for x,y in Iterable}

列表推导式:

列表推到式,遍历出来的数据最终就会变成一个列表数据。

基本语法

列表中存入10条数据:

# 常规写法
lst = []
for i in range(1, 11):
    lst.append(i)
print(lst)  # [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

# 推导式写法
lst = [i for i in range(1, 11)]
print(lst)  # [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

其它使用方法

单循环推导式:

# 处理容器中的数据:[1, 2, 3, 4, 5] -> [3, 6, 9, 12, 15]
lst = [1, 2, 3, 4, 5]
# 普通写法
new_lst = []
for i in lst:
	res = i * 3
	new_lst.append(res)
print(new_lst)  # [3, 6, 9, 12, 15]

# 推导式写法
new_lst = [i * 3 for i in lst]
print(new_lst)  # [3, 6, 9, 12, 15]

带有判断条件的单循环推导式:

# 过滤出奇数
lst = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
# 普通写法
new_lst = []
for i in lst:
	if i % 2 == 1:
		new_lst.append(i)
print(new_lst)  # [1, 3, 5, 7, 9]

# 推导式写法
# 推导式使用单项分支只能是在for语句结束之后使用
new_lst = [i for i in lst if i % 2 == 1]
print(new_lst)  # [1, 3, 5, 7, 9]

多循环推导式:

# 两个列表中的数据相加求和
lst = [1, 2, 3]
lst1 = [11, 22, 33]
# 普通方法
new_lst = []
for i in lst:
	for j in lst1:
		res = i + j
		new_lst.append(res)
print(new_lst)  # [12, 23, 34, 13, 24, 35, 14, 25, 36]

# 推导式写法
new_lst = [i + j for i in lst for j in lst1]
print(new_lst)  # [12, 23, 34, 13, 24, 35, 14, 25, 36]

列表推导式练习题

  • 1、将字典中的数据变成['x=A', 'y=B', 'z=c']的样式

{'x': 'A', 'y': 'B', 'z': 'C' }

  • 2、将所用元素变成纯小写

["ADDD","dddDD","DDaa","sss"]

  • 3、x是0-5之间的偶数,y是0-5之间的奇数 把x,y组成一起变成元组,放到列表当中
  • 4、使用列表推导式 制作所有99乘法表中的运算
  • 5、求M,N中矩阵和元素的乘积

M = [[1,2,3], [4,5,6], [7,8,9]]
N = [[2,2,2], [3,3,3], [4,4,4]]

# 第五题解法之一

# =>实现效果1   [2, 4, 6, 12, 15, 18, 28, 32, 36]
# =>实现效果2   [[2, 4, 6], [12, 15, 18], [28, 32, 36]]
# 实现效果 1
lst_new = []
for i in range(len(M)) :
	for j in range(len(N)) :
		res = M[i][j] * N[i][j]
		lst_new.append(res)
print(lst_new)
# 推导式写法
res = [M[i][j]*N[i][j] for i in range(len(M)) for j in range(len(N))]
print(res)
# 实现效果 2
lst_new = []
for i in range(len(M)) :
	lst_new2 = []
	for j in range(len(N)) :
		res = M[i][j] * N[i][j]
		lst_new2.append(res)
	lst_new.append(lst_new2)
print(lst_new)
# 推导式写法
res = [[M[i][j]*N[i][j] for j in range(len(M))] for i in range(len(N))]
print(res)

集合推导式

集合推导式和列表推导式的用法基本一样,但是外面使用大括号包括,得到的数据是一个集合。

例题:

'''
案例:
	满足年龄在18到21,存款大于等于5000,小于等于5500的人
	开卡格式为:尊贵VIP卡老X(姓氏),否则开卡格式为:抠脚大汉老X(姓氏)
	把开卡的种类统计出来
'''
lst = [
	{"name": "刘鑫炜", "age": 18, "money": 10000},
	{"name": "刘聪", "age": 19, "money": 5100},
	{"name": "刘子豪", "age": 20, "money": 4800},
	{"name": "孔祥群", "age": 21, "money": 2000},
	{"name": "宋云杰", "age": 18, "money": 20}
]

# 常规写法
setvar = set()

for i in lst:
	if (18 <= i['age'] <= 21) and (5000 <= i['money'] <= 5500):
		res = '尊贵VIP老' + i['name'][0]
	else:
		res = '抠脚老汉' + i['name'][0]
	setvar.add(res)
print(setvar)   # {'尊贵VIP老刘', '抠脚老汉刘', '抠脚老汉孔', '抠脚老汉宋'}
# 打印显示只有4个元素,是因为集合的自动去重

# 使用集合推导式
# 推导式只能使用单项分支,但是可以在返回值使用三元运算符
setvar = {
	"尊贵VIP卡老" + i["name"][0] if 18 <= i["age"] <= 21 and 5000 <= i["money"] <= 5500 else "抠脚大汉卡老" + i["name"][0] for i in lst}
print(setvar)   # {'抠脚大汉卡老孔', '抠脚大汉卡老刘', '尊贵VIP卡老刘', '抠脚大汉卡老宋'}

字典推导式

字典推导式也是一样的用法,但是字典的数据是以键值对的形式存在的,所以返回的数据、或者要将返回的数据变成两个,以对应键值。

基础语法:

将列表中的键值对的变成一个字典

lst = [{'A': 'a'}, {'B': 'b'}]

dct = {k:v for i in lst for k,v in i.items()}

print(dct)  # {'A': 'a', 'B': 'b'}

字典推导式常用以配合的函数

函数 作用
enumerate 枚举,根据索引号码将可迭代对象中的值一一配对成元组,返回迭代器。
zip 将多个可迭代对象中的值一一对应组成元组,返回迭代器。

enumerate

功能:

枚举,根据索引号码 和 Iterable 中的值,一个一个拿出来配对组成元组,放入迭代器中,然后返回迭代器。

语法:

enumerate(iterable, [start = 0])

参数:

iterable:可迭代数据
start:可以选择开始的索引号(默认从0开始索引)

基本语法:

from collections import Iterator
lst = ['东', '南', '西', '北']
# 基本使用
it = enumerate(lst)  # 实现功能返回迭代器
print(isinstance(it, Iterator))	 # True
# 强转成列表
new_lst = list(it)
print(new_lst)  # [(0, '东'), (1, '南'), (2, '西'), (3, '北')]
"""
可以看到里面的元列表中的数据和对应的索引号码一一对应成了元组
"""

上面的举例当中,如果使用字典推导式和enumerate函数配合,就可以用一句话达成组成一个字典的目的。

from collections import Iterator
lst = ['东', '南', '西', '北']
# enumerate 配合使用字典推导式 变成字典
dct = {k: v for k, v in enumerate(lst)}
print(dct)  # {0: '东', 1: '南', 2: '西', 3: '北'}

zip

功能:

将多个Iterable中的值,一个一个拿出来配对组成元组放入迭代器中,如果某个元素多出,没有匹配项就会被舍弃。

语法:

zip(iterable, iterable1, ……)

参数就是一个个的可迭代对象。

基本语法:

下面的举例当中,将三个列表中的元素以一一对应组成元组,但是最小的列表中只有三个元素,所以只能一一对应组成三对元组,而多出的元素就被舍弃。

lst1 = [1, 2, 3, 4, 5]
lst2 = ['a', 'b', 'c', 'd']
lst3 = ['A', 'B', 'C']
it = zip(lst1, lst2, lst3)
lst = list(it)
print(lst)  # [(1, 'a', 'A'), (2, 'b', 'B'), (3, 'c', 'C')]

为什么没有元组推导式?

推导式我们到此学习完了,但是我们就发现,推导式就是在容器中使用一个for循环而已,为什么没有元组推导式?

优先使用推导式

在有的时候,我们需要在一个列表或者其它的一些容器中存放大量的值,我们一般会怎么使用呢?比如在初始化一个列表的时候我们使用for循环和append的方法去创建吗?

这里大家注意,如果条件允许的话,那么我们一定是要优先使用推导式而不是for循环加append的方式,原因很简单,因为底层逻辑的不同,使推导式的执行速度相比for循环加append更快。

import time
# 列表循环插入数据
start_time = time.perf_counter()
lst = []
for i in range(15000000):
    lst.append(i)
end_time = time.perf_counter()
print(end_time - start_time)  # 1.7453036000000002

""" 推导式比循环速度更快 """
start_time = time.perf_counter()
new_lst1 = [i for i in range(15000000)]
end_time = time.perf_counter()
print(end_time - start_time)  # 0.7337192000000001

经过测试我们可以看到,推导式的速度大约是for循环的2倍多,是什么导致的?还记得我们之前使用过的dis模块吗?

import dis
def loop():
    lst = []
    for i in range(10):
        lst.append(i)
    return lst
def der():
    lst = [i for i in range(10)]
    return lst
dis.dis(loop)
print('-' * 100)
dis.dis(der)

结果如下:

4           0 BUILD_LIST               0
              2 STORE_FAST               0 (lst)
  5           4 SETUP_LOOP              26 (to 32)
              6 LOAD_GLOBAL              0 (range)
              8 LOAD_CONST               1 (10)
             10 CALL_FUNCTION            1
             12 GET_ITER
        >>   14 FOR_ITER                14 (to 30)
             16 STORE_FAST               1 (i)
  6          18 LOAD_FAST                0 (lst)
             20 LOAD_ATTR                1 (append)
             22 LOAD_FAST                1 (i)
             24 CALL_FUNCTION            1
             26 POP_TOP
             28 JUMP_ABSOLUTE           14
        >>   30 POP_BLOCK
  7     >>   32 LOAD_FAST                0 (lst)
             34 RETURN_VALUE
-----------------------------------------------------------------------------
 11           0 LOAD_CONST               1 (<code object <listcomp> at 0x000002C71AD950C0, file "tset.py", line 11>)
              2 LOAD_CONST               2 ('der.<locals>.<listcomp>')
              4 MAKE_FUNCTION            0
              6 LOAD_GLOBAL              0 (range)
              8 LOAD_CONST               3 (10)
             10 CALL_FUNCTION            1
             12 GET_ITER
             14 CALL_FUNCTION            1
             16 STORE_FAST               0 (lst)
 12          18 LOAD_FAST                0 (lst)
             20 RETURN_VALUE

从上述结果中我们就是可以看出,在这种情况下,for循环因为开始定义列表、循环中的append方法的是使用,比推导式要多出几个环节,因此速度相比之下变得很慢,这就是原因。

再次我们也再说一句,之后碰到关于速度和底层之类的疑惑的时候,就可以简单的使用timeitdis去验证和简答的理解。

到此这篇关于Python推导式使用详情的文章就介绍到这了,更多相关Python推导式内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • python 特有语法推导式的基本使用

    目录 列表推导式 字典推导式 集合推导式 共有三种推导式 列表(list)推导式 字典(dict)推导式 集合(set)推导式 列表推导式 基本语法: [out_express for out_express in input_list] 举个栗子 生成一个[0,1,4,9,16]的列表 在未学习推导式之前,我们可以这样实现 li = [] for i in range(5): # 循环5次取值 res_i = i * i # 进行每次取值的处理 li.append(res_i) # 将处理的值

  • python中从for循环延申到推导式的具体使用

    本文采用循序渐进的写法,逐步递进. 传统for循环: #获取1到1000000的偶数 #采用传统写法(俗称普通解析) for i in range(1,10**6+1): if(i%2==0): print(i) #程序运行结果: #2 #4 #. #. #. #1000000 总结(从直观上对代码进行评价):能完成要求,但是代码不够简洁. 改进后的代码,采用列表推导式: #获取1到1000000的偶数 #采用列表推导式(俗称列表解析) print([i for i in range(1,10*

  • python 列表推导式使用详解

    所谓的列表推导式,就是指的轻量级循环创建列表. 基本使用方式 # 创建一个0-10的列表 a = [x for x in range(11)] print(a) """ 输出结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] """ 上面的列表推导式等价于下面,只是代码非常简化. a = [] for x in range(10): a.append(x) 在循环的过程中使用if # 创建一个1-10之间偶数的列表 a = [x

  • Python列表推导式的使用方法

    1.列表推导式书写形式: [表达式 for 变量 in 列表]    或者  [表达式 for 变量 in 列表 if 条件] 2.举例说明: 复制代码 代码如下: #!/usr/bin/python# -*- coding: utf-8 -*- li = [1,2,3,4,5,6,7,8,9]print [x**2 for x in li] print [x**2 for x in li if x>5] print dict([(x,x*10) for x in li]) print  [ (

  • python推导式的使用方法实例

    前言 推导式提供了更简洁高效的方法来生成序列而又不失代码的可读性. 定义: 推导式是 Python 里很有用的一个特性,它可以用一行代码就可以创建一个新的序列(比如:列表,集合,字典等等).通过这个性能,不仅可以少写很多代码,而且性能上也更快. Python 里有四种推导式: 列表推导式(List Comprehensions) 字典推导式(Dictionary Comprehensions) 集合推导式(Set Comprehensions) 生成器推导式(Generator Comprehe

  • Python中的推导式使用详解

    推导式是Python中很强大的.很受欢迎的特性,具有语言简洁,速度快等优点.推导式包括: 1.列表推导式 2.字典推导式 3.集合推导式 嵌套列表推导式 NOTE: 字典和集合推导是最近才加入到Python的(Python 2.7 和Python 3.1以上版). 下面简要介绍下: [列表推导式] 列表推导能非常简洁的构造一个新列表:只用一条简洁的表达式即可对得到的元素进行转换变形 其基本格式如下: 复制代码 代码如下: [expr for value in collection ifcondi

  • python列表推导式的原理及使用方法

    偶尔会在python中看见这样一行代码: data = [x**2 for x in range(0, 5)] # 此时data = [0, 1, 4, 9, 16] 如果不知道背后的语法规则,那么很难理解为什么可以在列表的方括号中写一个“for”循环?实际上,这种语法称为列表推导式,和lambda表达式类似,都是在代码很短的情况下被使用. 本文将从两个方面讲解列表推导式: (1)什么是列表推导式 (2)如何使用列表推导式 1.什么是列表推导式? 列表推导式对应的英文是list comprehe

  • Python推导式使用详情

    目录 推导式 什么是推导式 基本语法 其它使用方法 列表推导式练习题 集合推导式 字典推导式 字典推导式常用以配合的函数 enumerate zip 优先使用推导式 推导式 什么是推导式 推导式是 for 循环的简化使用方法,使用推导式,将一个可迭代对象中的数据遍历到某一个容器当中.简单的来说就是用一行for循环语句,遍历一个可迭代对象中的所有数据,然后将遍历出来的数据进行处理放入对应的容器中的一个过程和方式. 和推导类似作用的还有三元运算符,三元运算符是条件判断语句的简化使用方法. 语法: v

  • Python推导式简单示例【列表推导式、字典推导式与集合推导式】

    本文实例讲述了Python推导式.分享给大家供大家参考,具体如下: 1. 列表推导式 >>> li = [1,2,3,4,5,6] # 求元素的平方 >>> li_a = [x**2 for x in li ] >>> li_a [1, 4, 9, 16, 25, 36] # 提取偶数值 >>> li_b = [x for x in li if x%2==0] >>> li_b [2, 4, 6] # 将多维数组转换

  • Python 推导式、生成器与切片问题解决思路

    推导式.生成器与切片 一.实验要求 1.理解并掌握序列中的常用操作.2.理解并掌握推导式.切片等用法并能解决实际问题. 二.实验内容 1,编写程序,测试字符的出现频率. #use dict method1 data = ['a','2',2,3,6,'2','b',4,7,2,'6','d',6,'a','z'] frequences=dict() for item in data: if item in frequences: frequences[item] += 1 else: frequ

  • Python推导式数据处理方式

    目录 前言 1.列表推导式 2.元组推导式 3.集合推导式 4.字典推导式 前言 推导式是一种独特的数据处理方式,可以快速的从一个数据序列构建另一个新的数据序列的结构体.常用的推导式有一下四种: 列表推导式 元组推导式 集合推导式 字典推导式 1.列表推导式 # coding:utf-8 # Author:Yang Xiaopeng """ 语法格式 [表达式 for 变量 in 变量] [表达式 for 变量 in 变量 if 条件表达式] 上述格式中 的 表达式中的变量与

  • python生成器推导式用法简单示例

    本文实例讲述了python生成器推导式用法.分享给大家供大家参考,具体如下: 1.生成器推导式是继列表推导式后的有一中python推导式,他比列表推导式速度更快,占用的内存也更少. 2.使用生成器对象时,可以根据需要将他转化为列表或者元组,也可以是哟个生成器对像__next__()方法或内置函数next()进行遍历,其具有惰性求值的特点,进行一次遍历后便不能再次方位内部元素,即访问一次立马清空生成器对象 >>> g = ((i+2)**2 for i in range(10)) >

  • Python简洁优雅的推导式示例详解

    前言 推导式是从一个或者多个迭代器快速创建序列的一种方法.它可以将循环和条件判断结合,从而避免冗长的代码.推导式是典型的 Python 风格 Python语言有一种独特的推导式语法,相当于语法糖的存在,可以帮助你在某些场合写出较为精简酷炫的代码.但没有它,也不会有太多影响.Python语言有几种不同类型的推导式. 1. 列表推导式 列表推导式是一种快速生成列表的方式.其形式是用方括号括起来的一段语句,如下例子所示: lis = [x * x for x in range(1, 10)] prin

  • Python列表推导式,元组推导式,字典推导式,集合推导式

    目录 1 介绍 2 列表推导式 3 元组推导式 4 字典推导式 5 集合推导式 1 介绍 推导式(解析器):是Python独有的一种特性.使用推导式可以快速生成列表.元组.字典以及集合类型的数据,因此推导式又可分为列表推导式. 2 列表推导式 格式: 格式1: [表达式 for 变量 in 列表][out_exp_res for out_exp in input_list] 格式2:[表达式 for 变量 in 列表 if 条件][out_exp_res for out_exp in input

  • Python列表推导式详情

    目录 1.列表生成式 1.1 案例 2.集合生成式 3.字典生成式 1.列表生成式 列表生成式即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式. 语法结构如下: # 普通的生成式 [表达式 for 变量 in 旧列表] # 加条件的生成式 [表达式 for 变量 in 旧列表 if 条件] # if...else条件的生成式 [表达式 if 条件1 else 条件2for 变量 in 旧列表] 1.1 案例 过滤掉名词字母不足4的名字,示

随机推荐