python三元表达式详解_Python基础(9)三元表达式、列表解析、生成器表达式

一、三元表达式

三元运算,是对简单的条件语句的缩写。

# if条件语句

if x > f:

print(x)

else:

print(y)

# 条件成立左边,不成立右边

x if x > y else y # 三元表达式

python的三元运算格式如下:

result=值1 if x

# 如果条件成立,那么将“值1”赋值给result变量,否则,将“值2”赋值给result变量

二、列表解析

列表解析:用三元表达式,将结果写入列表,即为列表解析

运用列表生成式,可以写出非常简洁的代码。

如果要生成[1x1, 2x2, 3x3, ..., 10x10]怎么做?方法一是循环:

#方法一

L = []

for x in range(1, 11):

L.append(x * x)

#结果L

[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

# 方法二:列表解析

[x * x for x in range(1, 11)]

[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

写列表生成式时,把要生成的元素x * x放到前面,后面跟for循环,就可以把list创建出来,十分有用,多写几次,很快就可以熟悉这种语法。

for循环后面还可以加上if判断:

[x * x for x in range(1, 11) if x % 2 == 0]

[4, 16, 36, 64, 100]

还可以使用两层循环,可以生成全排列:

[m+n for m in 'ABC' for n in 'XYZ']

['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']

三层和三层以上的循环就很少用到了。

for循环还可以同时使用两个甚至多个变量,比如dict的items()可以同时迭代key和value:

d = {'x': 'A', 'y': 'B', 'z': 'C'}for k, v ind.items():print(k, '=', v)

y=B

x=A

z= C

因此,列表生成式也可以使用两个变量来生成list:

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

[k+ '=' + v for k, v ind.items()]

['y=B', 'x=A', 'z=C']

列表解析实例

#遍历

s='hello'l=[]for i ins:

res=i.upper()

l.append(res)print(l)

#####################################

#列表解析:

s='hello'res=[i.upper() for i ins]

print(res)

要求:列出1~10所有数字的平方####################################################

1、普通方法:>>> L =[]>>> for i in range(1,11):

... L.append(i**2)

...>>> printL

[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]####################################################

2、列表解析>>>L = [ i**2 for i in range(1,11)]>>>printL

[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

要求:列出1~10中大于等于4的数字的平方####################################################

1、普通方法:>>> L =[]>>> for i in range(1,11):

...if i >= 4:

... L.append(i**2)

...>>> printL

[16, 25, 36, 49, 64, 81, 100]####################################################

2、列表解析>>>L = [ i**2 for i in range(1,11) if i >= 4]>>>printL

[16, 25, 36, 49, 64, 81, 100]

要求:列出"/var/log"中所有已'.log'结尾的文件##################################################

1、普通方法>>>importos>>>file =[]>>> for file in os.listdir('/var/log'):

...if file.endswith('.log'):

... file.append(file)

...>>> printfile

['anaconda.ifcfg.log', 'Xorg.0.log', 'anaconda.storage.log', 'Xorg.9.log', 'yum.log', 'anaconda.log', 'dracut.log', 'pm-powersave.log', 'anaconda.yum.log', 'wpa_supplicant.log', 'boot.log', 'spice-vdagent.log', 'anaconda.program.log']##################################################

2.列表解析>>> importos>>> file = [ file for file in os.listdir('/var/log') if file.endswith('.log') ]>>> printfile

['anaconda.ifcfg.log', 'Xorg.0.log', 'anaconda.storage.log', 'Xorg.9.log', 'yum.log', 'anaconda.log', 'dracut.log', 'pm-powersave.log', 'anaconda.yum.log', 'wpa_supplicant.log', 'boot.log', 'spice-vdagent.log', 'anaconda.program.log']

小结

运用列表生成式,可以快速生成list,可以通过一个list推导出另一个list,而代码却十分简洁。

三、生成器表达式

egg_list=['鸡蛋%s' %i for i in range(10)] #列表解析

#############################################

laomuji=('鸡蛋%s' %i for i in range(10))#生成器表达式

print(laomuji)print(next(laomuji)) #next本质就是调用__next__

print(laomuji.__next__())print(next(laomuji))

总结:

1.把列表解析的[]换成()得到的就是生成器表达式

2.列表解析与生成器表达式都是一种便利的编程方式,只不过生成器表达式更节省内存

3.Python不但使用迭代器协议,让for循环变得更加通用。大部分内置函数,也是使用迭代器协议访问对象的。

例如, sum函数是Python的内置函数,该函数使用迭代器协议访问对象,而生成器实现了迭代器协议,所以,我们可以直接这样计算一系列值的和:

sum(x ** 2 for x in xrange(4))

而不用多此一举的先构造一个列表:

sum([x ** 2 for x in xrange(4)])

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值