Я не слишком знаком с 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)