¿Cómo agrupar elementos en python por n elementos?

Posible duplicado:
¿Cómo se divide una lista en trozos de tamaño uniforme en Python?

Me gustaría obtener grupos de elementos de tamaño n de una lista l:

es decir:

[1,2,3,4,5,6,7,8,9] -> [[1,2,3], [4,5,6],[7,8,9]] where n is 3 

Puede utilizar el agrupador de las recetas en la página de documentación de itertools:

 def grouper(n, iterable, fillvalue=None): "grouper(3, 'ABCDEFG', 'x') --> ABC DEF Gxx" args = [iter(iterable)] * n return izip_longest(fillvalue=fillvalue, *args) 

Bueno, la respuesta de la fuerza bruta es:

 subList = [theList[n:n+N] for n in range(0, len(theList), N)] 

donde N es el tamaño del grupo (3 en su caso):

 >>> theList = list(range(10)) >>> N = 3 >>> subList = [theList[n:n+N] for n in range(0, len(theList), N)] >>> subList [[0, 1, 2], [3, 4, 5], [6, 7, 8], [9]] 

Si desea un valor de relleno, puede hacerlo justo antes de la comprensión de la lista:

 tempList = theList + [fill] * N subList = [tempList[n:n+N] for n in range(0, len(theList), N)] 

Ejemplo:

 >>> fill = 99 >>> tempList = theList + [fill] * N >>> subList = [tempList[n:n+N] for n in range(0, len(theList), N)] >>> subList [[0, 1, 2], [3, 4, 5], [6, 7, 8], [9, 99, 99]] 

Vea los ejemplos en la parte inferior de los documentos de itertools: http://docs.python.org/library/itertools.html?highlight=itertools#module-itertools

Quieres el método “mero”, o algo así.

Qué tal si

 a = range(1,10) n = 3 out = [a[k::k+n] for k in range(0,len(a),n)] 
 answer = [L[3*i:(3*i)+3] for i in range((len(L)/3) +1)] if not answer[-1]: answer = answer[:-1]