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]

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

120101列表解析式.png

    在前面学过,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表达式和解析式,一行代码就实现,是不是觉得解析很强大?

本文地址:https://www.cnblogs.com/surpassme/p/12983479.html
本文同步在微信订阅号上发布,如各位小伙伴们喜欢我的文章,也可以关注我的微信订阅号:woaitest,或扫描下面的二维码添加关注:
MyQRCode.jpg

猜你喜欢

转载自www.cnblogs.com/surpassme/p/12983479.html