# 集合推导式 {}类似列表推导式,在列表推导式的基础上添加了一个去除重复项 list1 = [1, 2, 1, 3, 5, 2, 1, 8, 9, 7] set1 = {x + 1 for x in list1 if x > 5} print(set1) # 字典推导式 dict1 = {'a': 'A', 'b': 'B', 'c': 'C', 'd': 'C'} newdict = {value: key for key, value in dict1.items()} print(newdict)
# 生成器 ''' 得到生成器方式 1.通过列表推导式得到生成器 ''' # [0,3,6,9,12,15,18,21,...,27] newlist = [x * 3 for x in range(10)] print(newlist) # 得到生成器 generator g = (x * 3 for x in range(10)) print(type(g)) print(g) # 通过调用__next__() 方式得到元素 print(g.__next__()) # 0 print(g.__next__()) # 3 print(g.__next__()) # 6 # 方式2:next(生成器对象) builtins系统内置函数 # 每调用一次next则会产生一个元素 print(next(g)) # StopIteration 生成器本来可以产生10个,得到10个,在调用next(g),抛出异常
g = (x * 3 for x in range(10)) while True: try: e = next(g) print(e) except: print("没有更多元素啦!") break
--------------------------------------------------------------------------------
g = (x * 3 for x in range(10)) while True: try: e = next(g) print(e) except: print("没有更多元素啦!") break # 定义生成器的方式二:借助函数完成 # 函数中出现了yield关键字,说明函数就不是函数,变成生成器 # 斐波那契数列 ''':cvar 步骤: 1.定义一个函数,函数中使用yield关键字 2.调用函数,接收调用的结果 3.得到的结果就是生成器 4.借助于next(), __next__()得到元素 ''' def func(): n = 0 while True: n += 1 print(n) yield n # return n + 暂停 g = func() print(g) print(next(g)) print(next(g)) print(next(g)) print(next(g)) def fib(length): a, b = 0, 1 n = 0 while n < length: # print(b) yield b # return b + 暂停 a, b = b, a + b n += 1 return 'abc' # return就是在得到StopIteration得到后的提示信息 g = fib(8) print(next(g)) print(next(g)) print(next(g)) print(next(g)) print(next(g)) print(next(g))