python字典解析式_Python基础-12解析式

12.解析式

解析式是将一个可迭代对象转换另一个可迭代对象的工具。在Python,容器类型的数据(str,tuple,list,dict,set)都是可迭代对象。

第一个可迭代对象:可以是任何容器类型数据

第二个可迭代对象:生成的最终类型解析式,常见的列表解析如下所示:

列表解析式:可迭代对象为list

集体解析式:可迭代对象为set

字典解析式:可迭代对象为dict

先来看看其语法格式如下所示:

# 列表解析式

[item for item in 可迭代对象 if 条件 ]

# 集合解析式

(item for item in 可迭代对象 if 条件 )

# 字典解析式

{item for item in 可迭代对象 if 条件 }

从语法格式看起来,就是for循环和if的结合体,但却非常简洁。至于最终生成的数据类型,可以根据其定义的格式就可以猜出。

12.1 列表解析式

先来看看一个需求,将0~10以内的偶数挑选出来,并输出其列表结果。实现方法如下所示:

1.方法1:

通过判断是否能与2整除获取

evenList=[]

for item in range(0,11):

if item%2==0:

evenList.append(item)

2.方法2

通过控制步长实现

evenList=[]

for item in range(0,11,2):

evenList.append(item)

3.方法3

通过列表解析式

[item for item in range(0,11) if item%2==0]

以上示例的详细示意图如下所示(以不同颜色进行区分):

在前面学过,for循环是可以进行嵌套的,那多个for循环的是不是也可以使用列表解析式?答案当然是肯定的,下面将演示在给定的路径下递归列出是文件的文件,并以列表的形式返回完整的路径,如下所示:

import os

def getfiles(path):

fileList=[os.path.join(r,f) for r,_,fs in os.walk(path) for f in fs if os.path.isfile(os.path.join(r,f))]

return fileList

12.2 其他解析式

另外两种解析(集合、字典)与列表解析都一样,只需要注意在定义时的区别即可。

1.字典解析式

# 传统方式

tempDict={}

for k,v in (("a","b"),("c","d"),("e","f"),("g","h")):

if k not in ("g"):

tempDict[k]=v

# 字典解析式

tempDict={k:v for k,v in (("a","b"),("c","d"),("e","f")) if k not in ("g") }

print(tempDict)

2.集合解析式

# 传统方式

tempSet=set()

for item in (1,1,2,3,4,5,6,7,4,6):

if item >=2:

tempSet.add(item)

# 集合解析式

tempSet={item for item in (1,1,2,3,4,5,6,7,4,6) if item >=2 }

3.元组解析式

严格来讲,官方并没有元组解析式这种说法,如果像列表、字典和集合一样,最终生成的是一个生成器对象,如果要想生成的结果为元组的形式,需要使用函数tuple(),如下所示:

>>> tuple(item for item in (1,1,2,3,4,5,6,7,4,6) if item >=2)

(2, 3, 4, 5, 6, 7, 4, 6)

12.3 与lambda的结合使用

lambda可以做为匿名函数使用,当然也可以与解析结合使用,示例如下所示:

# 将元组拆分为列表

tmpList=(1,2,3,(4,5,6),(7,8),9,((10,20,30),(40,50)))

f=lambda x:[ v for item in x for v in f(item)] if isinstance(x,(tuple,)) else [x]

print(f(tmpList))

输出结果为:

[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 20, 30, 40, 50]

以上示例是将一个元组拆分为列表形式,元组数据中里面还包含有元组,这需要使用递归。使用lambda表达式和解析式,一行代码就实现,是不是觉得解析很强大?

本文同步在微信订阅号上发布,如各位小伙伴们喜欢我的文章,也可以关注我的微信订阅号:woaitest,或扫描下面的二维码添加关注:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值