-1

Question 1

how to make an iterable object like this:

0 1 2 3 4 5 4 3 2 1 0 1 2 3 4 5 4 3 2 1 0 1 2 3 4 5 4 3 2 1 ....

Question 2

if use list(obj) on the object above would this eat up machine's memory? how to prevent it?

Please don't use python2

Max
  • 7,957
  • 10
  • 33
  • 39

2 Answers2

3

You can make an infinite generator that counts up and down:

def updown(n):
    while True:
        for i in range(n):
            yield i
        for i in range(n - 2, 0, -1):
            yield i

uptofive = updown(6)
for i in range(20):
    print uptofive.next(),

would output:

0 1 2 3 4 5 4 3 2 1 0 1 2 3 4 5 4 3 2 1

You cannot prevent list(updown(6)) from trying to consume all memory, no. As the doctor would say: "Then don't do that!".

Use .next() calls instead, or use your generator with another statement that limits the number of times you iterate over the generator. The itertools.islice() function would do just that:

import itertools
list(itertools.islice(updown(6), 20))
Martijn Pieters
  • 1,048,767
  • 296
  • 4,058
  • 3,343
1

An alternative is to use itertools.cycle():

from itertools import cycle

def oscillator(start, stop):
    # assumes stop >= start
    return cycle(range(start, stop+1) + range(stop-1, start, -1))

o = oscillator(0, 5)
for i in range(30):
    print o.next(),
mhawke
  • 84,695
  • 9
  • 117
  • 138