三元表达式,列表解析和生成器表达式

在以前,在诸如比较两个数大小的时候,通常的写法都是下面的样子

if x > y: print("the max is x") else: print("the max is y")

三元表达式的语法为:

True if expression else False

现在可以个体三元表达式来完成这种比较简单的判断

res = x if x > y else y print(res) 列表解析

列表解析的语法格式为

[ i操作 for i in 列表 if 表达式1 and 表达式2]

其中if判断语句是可选语句,可以对列表的元素进行操作

现在有这样一个需求,把一个数字列表中的每个值都取平方,把一个列表中的每个字符串都转换为大写形式

可以这样写

l1 = range(1, 10, 2) l2 = [] for i in l1: l2.append(i**2) l3 = ['python', 'linux', 'javascript', 'mysql'] l4 = [] for j in l3: j = j.upper() l4.append(j) print(l2) print(l4)

那有没有简单的方式呢,可以使用列表解析,上面的例子则可以修改为

l1 = range(1, 10, 2) l2 = [i**2 for i in l1] l3 = ['python', 'linux', 'javascript', 'mysql'] l4 = [j.upper() for j in l3] print(l2) print(l4) 生成器表达式

列表解析得到的结果仍然是一个列表,列表解析的优点是:取值方便
缺点:很占系统资源,如果列表的长度较小时使用列表解析会很方便,但是如果列表的长度很大的时候,使用列表解析会占用很多的内存资源,此时可以使用生成器表达式来节省内存资源
来看下面的例子

res = ( i**2 for i in range(100)) print(res)

得到的结果为

<generator object <genexpr> at 0x0000000002DA1AF0>

在上面的例子里,把列表解析表达式中的中括号换成小括号,那么表达式执行结果就变成了一个生成器

我们知道,生成器的本质就是迭代器,所以上面的表达式执行的结果生成器,可以使用for 循环来取值

res = ( i**2 for i in range(100)) for i in res: print(i)

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zyjxpj.html