Pythonic способ эмуляции itertools.product в python 2.4

#python #itertools #python-2.4

#python #python-itertools #python-2.4

Вопрос:

У меня есть скрипт на python 3, который использует itertools.product , но мне нужно иметь возможность запускать его на компьютере, на котором установлен только python 2.4. Поскольку itertools.product это новое в python 2.6, у меня больше нет доступа к этой функции.

Как я могу эмулировать itertools.product в Python 2.4 способом pythonic?

Ответ №1:

Эквивалентный код из http://docs.python.org/library/itertools.html#itertools.product

 def product(*args, **kwds):
    # product('ABCD', 'xy') --> Ax Ay Bx By Cx Cy Dx Dy
    # product(range(2), repeat=3) --> 000 001 010 011 100 101 110 111
    pools = map(tuple, args) * kwds.get('repeat', 1)
    result = [[]]
    for pool in pools:
        result = [x [y] for x in result for y in pool]
    for prod in result:
        yield tuple(prod)
  

Ответ №2:

Я не слишком знаком с python 2.4, но в соответствии с документами 2.7:

Эта функция эквивалентна следующему коду, за исключением того, что фактическая реализация не создает промежуточные результаты в памяти:

 def product(*args, **kwds):
    # product('ABCD', 'xy') --> Ax Ay Bx By Cx Cy Dx Dy
    # product(range(2), repeat=3) --> 000 001 010 011 100 101 110 111
    pools = map(tuple, args) * kwds.get('repeat', 1)
    result = [[]]
    for pool in pools:
        result = [x [y] for x in result for y in pool]
    for prod in result:
        yield tuple(prod)