Context Managers
上下文管理器,作用:
with open(filename, mode) as writer:
writer.write('Hello ')
writer.write('World')
简化这样的操作:
writer = open(filename, mode)
try:
writer.write('Hello ')
writer.write('World')
finally:
writer.close()
“with”是一个新关键词,并且总是伴随着上下文管理器出现。“open(filename, mode)”曾经在之前的代码中出现。“as”是另一个关键词,它指代了从“open”函数返回的内容,并且把它赋值给了一个新的变量。“writer”是一个新的变量名。
Generators
迭代时尽量用generator expression,内存占用少,效率高
for uppercase_name in [name.upper() for name in get_all_usernames()]:
process_normalized_username(uppercase_name)
用小括号生成generator
for uppercase_name in (name.upper() for name in get_all_usernames()):
process_normalized_username(uppercase_name)
yield的使用我 会再总结(从我自己笔记上直接粘了过来不是原来书上的内容了)
一个生成器函数的定义很像一个普通的函数,除了当它要生成一个值的时候,使用yield关键字而不是return。如果一个def的主体包含yield,这个函数会自动变成一个生成器(即使它包含一个return)。除了以上内容,创建一个生成器没有什么多余步骤了。
为了从生成器获取下一个值,我们使用next()函数,就像对付迭代器一样。
def get_primes(number):
while True:
if is_prime(number):
yield number
number += 1
第一次调用函数,会运行到yield停止,再调用会next(),从yield开始执行,循环到第二次yield 。。。。直到没有值