Pergunta

#!/usr/bin/python
#
# Description: I try to simplify the implementation of the thing below.
# Sets, such as (a,b,c), with irrelavant order are given. The goal is to
# simplify the messy "assignment", not sure of the term, below.
#
#
# QUESTION: How can you simplify it? 
#
# >>> a=['1','2','3']
# >>> b=['bc','b']
# >>> c=['#']
# >>> print([x+y+z for x in a for y in b for z in c])
# ['1bc#', '1b#', '2bc#', '2b#', '3bc#', '3b#']
#
# The same works with sets as well
# >>> a
# set(['a', 'c', 'b'])
# >>> b
# set(['1', '2'])
# >>> c
# set(['#'])
#
# >>> print([x+y+z for x in a for y in b for z in c])
# ['a1#', 'a2#', 'c1#', 'c2#', 'b1#', 'b2#']


#BROKEN TRIALS
d = [a,b,c]

# TRIAL 2: trying to simplify the "assignments", not sure of the term
# but see the change to the abve 
# print([x+y+z for x, y, z in zip([x,y,z], d)])

# TRIAL 3: simplifying TRIAL 2
# print([x+y+z for x, y, z in zip([x,y,z], [a,b,c])])

Atualizar Uma coisa faltando, e se você realmente tem for x in a for y in b for z in c ..., ou seja, quantidade de estruturas, escrevendo product(a,b,c,...) é complicado. Suponha que você tenha uma lista de listas como o d No exemplo acima. Você pode conseguir isso mais simples? Python vamos fazer unpacking com *a para listas e a avaliação do dicionário com **b Mas é apenas a notação. Os loops aninhados de comprimento arbitrário e a simplificação de tais monstros estão além, para mais pesquisas aqui. Quero enfatizar que o problema no título é aberto, por isso não seja equivocado se eu aceitar uma pergunta!

Foi útil?

Solução

>>> from itertools import product
>>> a=['1','2','3']
>>> b=['bc','b']
>>> c=['#']
>>> map("".join, product(a,b,c))
['1bc#', '1b#', '2bc#', '2b#', '3bc#', '3b#']

editar:

Você pode usar o produto em um monte de coisas como você gostaria de também

>>> list_of_things = [a,b,c]
>>> map("".join, product(*list_of_things))

Outras dicas

Tente isso

>>> import itertools
>>> a=['1','2','3']
>>> b=['bc','b']
>>> c=['#'] 
>>> print [ "".join(res) for res in itertools.product(a,b,c) ]
['1bc#', '1b#', '2bc#', '2b#', '3bc#', '3b#']
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top