2009-04-16 10 views
11

¿Cuál es la mejor manera de dividir esto:¿Tuple múltiple a dos pares en Python?

tuple = ('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h') 

en esto:

tuples = [('a', 'b'), ('c', 'd'), ('e', 'f'), ('g', 'h')] 

Suponiendo que la entrada tiene siempre un número par de valores.

+7

Usted puede no querer a una tupla con nombre variable, ya que sobrescribe la tupla función interna(). – recursive

Respuesta

36

zip() es su amigo:

t = ('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h') 
zip(t[::2], t[1::2]) 
+0

¡Buena alternativa! –

+1

+1 porque es bonito y no sabía acerca de la sintaxis [::] –

+0

no funciona para tuple = ('a', 'b', 'c', 'd', 'e', ​​'f ',' g ',' h ',' i ') # nota la última' i ', que hace que las tuplas odd-length – dfa

15
[(tuple[a], tuple[a+1]) for a in range(0,len(tuple),2)] 
+0

+1 uso más explícito de la función de rango –

-1

He aquí una receta general para cualquier tamaño de porción, si no siempre podría ser 2:

def chunk(seq, n): 
    return [seq[i:i+n] for i in range(0, len(seq), n)] 

chunks= chunk(tuples, 2) 

O, si te gusta iteradores :

def iterchunk(iterable, n): 
    it= iter(iterable) 
    while True: 
     chunk= [] 
     try: 
      for i in range(n): 
       chunk.append(it.next()) 
     except StopIteration: 
      break 
     finally: 
      if len(chunk)!=0: 
       yield tuple(chunk) 
+2

Creo que quería decir rango (0, len (seq), n), en lugar de rango (0, len (seq)) – Noah

+0

-1: no funciona. – nosklo

+0

Noah: ta, de hecho. – bobince

7

O nosotros, ing itertools (ver el recipe para grouper):

from itertools import izip 
def group2(iterable): 
    args = [iter(iterable)] * 2 
    return izip(*args) 

tuples = [ab for ab in group2(tuple)] 
+0

+1: por mencionar la documentación (llegaste primero :) – tzot

0

presento este código basado en Peter Hoffmann's answer como respuesta a dfa's comment.

Se garantiza que funciona independientemente de si su tupla tiene un número par de elementos.

[(tup[i], tup[i+1]) for i in range(0, (len(tup)/2)*2, 2)] 

El parámetro gama (len(tup)/2)*2 calcula el número más alto incluso menor o igual a la longitud de la tupla lo que se garantiza que funcione si o no la tupla tiene un número par de elementos.

El resultado del método va a ser una lista. Esto se puede convertir a tuplas usando la función tuple().

muestra:

def inPairs(tup): 
    return [(tup[i], tup[i+1]) for i in range(0, (len(tup)/2)*2, 2)] 

# odd number of elements 
print("Odd Set") 
odd = range(5) 
print(odd) 
po = inPairs(odd) 
print(po) 

# even number of elements 
print("Even Set") 
even = range(4) 
print(even) 
pe = inPairs(even) 
print(pe) 

salida

 
Odd Set 
[0, 1, 2, 3, 4] 
[(0, 1), (2, 3)] 
Even Set 
[0, 1, 2, 3] 
[(0, 1), (2, 3)]