Screenplay: Python: The Yield Statement¶
Fibonacci Numbers: Naive List¶
#!/usr/bin/python
def fibonacci():
fibo_numbers = []
previous = 1
current = 1
while True:
next = previous + current
fibo_numbers.append(next)
previous, current = current, next
return fibo_numbers
if __name__ == '__main__':
for num in fibonacci():
print(num)
watch OS become overly jerky, until process is OOM-killed
well, there’s need for a limit
Fibonacci Numbers: Naive List, Limited¶
#!/usr/bin/python
def fibonacci(max_numbers=100):
fibo_numbers = []
previous = 1
current = 1
while len(fibo_numbers) < max_numbers:
next = previous + current
fibo_numbers.append(next)
previous, current = current, next
return fibo_numbers
if __name__ == '__main__':
for num in fibonacci():
print(num)
Sideway: Infinity by Not Using Functions¶
Still not satisfactory
Want infinity
Can be done, by embedding the using code (
print()
) into the Fibonacci generation.not so modular though
#!/usr/bin/python
previous = 1
current = 1
while True:
next = previous + current
print(next)
previous, current = current, next
Fibonacci Numbers: Function Producing Infinite Sequence¶
#!/usr/bin/python
def fibonacci():
previous = 1
current = 1
while True:
next = previous + current
yield next
previous, current = current, next
if __name__ == '__main__':
for num in fibonacci():
print(num)
Common Pattern: Turn List into Generated Items¶
correct infinity can save a few lines
--- /home/jfasch/work/jfasch-home/trainings/material/soup/python/python_1010_generators_yield/code/10-fibo-list-nolimit.py
+++ /home/jfasch/work/jfasch-home/trainings/material/soup/python/python_1010_generators_yield/code/40-fibo-generator.py
@@ -1,16 +1,12 @@
#!/usr/bin/python
def fibonacci():
- fibo_numbers = []
-
previous = 1
current = 1
while True:
next = previous + current
- fibo_numbers.append(next)
+ yield next
previous, current = current, next
-
- return fibo_numbers
if __name__ == '__main__':
for num in fibonacci():