列表推导式、生成器表达式
一、列表生成式
优点: 简单、节省代码
缺点:占内存
l = [i for i in range(10)] print(l) l1 = ['选项%s'%i for i in range(10)] print(l1)
[ 变量(加工后的变量),for 变量i in 可迭代对象 ]
print(sum(i**2 for i in range(7))) 1 +4+9+16+25 print(l)--------55
列表推导式
1、30以内所有能被3整除的数
multiples = [i for i in range(30) if i % 3 is 0] print(multiples) # Output: [0, 3, 6, 9, 12, 15, 18, 21, 24, 27]
2、30以内所有能被3整除的数的平方
l = [i**2 for i in range(1,31) if i % 3 == 0] print(l)
3、找到嵌套列表中名字含有两个‘e’的所有名字
names = [['Tom', 'Billy', 'Jefferson', 'Andrew', 'Wesley', 'Steven', 'Joe'], ['Alice', 'Jill', 'Ana', 'Wendy', 'Jennifer', 'Sherry', 'Eva']] print([name for i in names for name in i if name.count('e') = 2])
字典推导式
例一:将一个字典的key和value对调 mcase = {'a': 10, 'b': 34} mcase_frequency = {mcase[k]: k for k in mcase} print(mcase_frequency)
集合推导式
例:计算列表中每个值的平方,自带去重功能
squared = {x**2 for x in [1, -1, 2]} print(squared) # Output: set([1, 4])
二、生成器表达式
优点:更节省内存
l = (i for i in range(10))------#不是元组 print(l)-------------------# <generator object <genexpr> at 0x00000000028A4A98>生成器对象 把列表解析的[]换成()得到的就是生成器表达式