# 原始斐波那契数列deffibonacci(n):
a =0
b =1
nums =[]for i inrange(n):
nums.append(a)
a, b = b, a + b
return nums
print(fibonacci(12))#yield 的作用就是把一个函数变成一个 generator,带有 yield 的函数不再是一个普通函数,# Python 解释器会将其视为一个 generator,调用 fibonacci(n) 不会执行 fibonacci 函数,# 而是返回一个 iterable 对象,在 for 循环执行时,每次循环都会执行 fibonacci 函数内部的代码,# 执行到 yield b 时,fibonacci 函数就返回一个迭代值,下次迭代时,代码从 yield b 的下一条语句继续执行,# 而函数的本地变量看起来和上次中断执行前是完全一样的,于是函数继续执行,直到再次遇到 yield。deffibonacci(n):
a =0
b =1# nums = []for i inrange(n):yield a
# nums.append(a)
a, b = b, a + b
# return numsfor i in fibonacci(12):print(i, end=' ')
f = fibonacci(5)print(f.__next__())print(f.__next__())print(f.__next__())print(f.__next__())print(f.__next__())print(f.__next__())01123
Traceback (most recent call last):
StopIteration
With语句会自动关闭文件
withopen('xxx.txt',encoding='utf-8')as file_in:for line in file_in:print(line)
三元操作
score =int(input())if score >=60:print("pass")else:print("fail")
s ="pass"if score >=60else"fail"
yield语法# 原始斐波那契数列def fibonacci(n): a = 0 b = 1 nums = [] for i in range(n): nums.append(a) a, b = b, a + b return numsprint(fibonacci(12))#yield 的作用就是把一个函数变成一个 generator,带有 yield 的函数不再是一个普通函数,# Python 解释器会将其视为一个