1.列表生成式
列表生成式是Python 内置的非常简单却强大的可以用来创建 list的生成式
思考:
要生成 list [1, 2, 3, 4, 5, 6, 7] 可以用 range(1, 8)
但如果要生成 [1x1, 2x2, 3x3, …, 7x7] 怎么做?
方法一:for循环
L = []
for x in range(1,8):
L.append(x*x)
print x
方法二:列表生成式
[x*x for x in range(1,8)]
循环太繁琐,而列表生成式则可以用一行语句代替循环生成上面的 list
2.生成器
1)为什么需要生成器?
•通过列表生成式,我们可以直接创建一个列表,受到内存限
制,列表容量肯定是有限的;
•创建一个包含 100 万个元素的列表,占用很大的存储空间;
2)生成器是什么?
• 在循环的过程中不断推算出后续的元素呢?这样就不必创
建完整的 list,从而节省大量的空间。在 Python 中,这种一
边循环一边计算的机制,称为生成器(Generator)
怎么创建生成器?把一个列表生成式的 [] 改成 ()
•使用g.next()方法依次读取元素(麻烦)
g = (x for x in range(4))
g.next()
g.next()
g.next()
g.next()
•使用 for 循环(推荐)
g = (x for x in range(4))
for x in g:
print x
1)c.next()
2)c.send()
3)throw方法: 给生成器发送一个异常;
def gen():
while True:
try:
yield 'a'
yield 'b'
except TypeError:
print 'Type Error'
except ValueError:
print 'value error'
g = gen()
# print g.next()
print next(g)
g.throw(ValueError)
# print g.next()
print next(g)
g = gen()
# print g.next()
print next(g)
g.throw(ValueError)
# print g.next()
print next(g)
3)generator
•函数顺序执行,遇return语句或最后一行函数语句就返回。
•generator函数在每次调用next() 的时候执行,遇到 yield 语
句返回,再次执行时从上次返回的yield 语句处继续执行。