Para obtener la mejor eficacia, generalmente desea procesar más de un bit a la vez. Puede usar un método simple para obtener una representación binaria de ancho fijo. p.ej.
def _bin(x, width):
return ''.join(str((x>>i)&1) for i in xrange(width-1,-1,-1))
_bin (x, 8) será ahora dar una representación acolchado cero de 8 bits inferiores de x. Esto se puede utilizar para crear una tabla de búsqueda, lo que permite que su convertidor procese 8 bits a la vez (o más si desea dedicarle la memoria).
_conv_table = [_bin(x,8) for x in range(256)]
Luego puede usar esto en su función real, quitando los ceros a la izquierda al devolverlo. También he añadido el manejo de números con signo, ya que sin ella obtendrá un bucle infinito (enteros negativos conceptualmente tienen un número infinito de bits de signo de ajuste.)
def bin(x):
if x == 0:
return '0' #Special case: Don't strip leading zero if no other digits
elif x < 0:
sign='-'
x*=-1
else:
sign = ''
l=[]
while x:
l.append(_conv_table[x & 0xff])
x >>= 8
return sign + ''.join(reversed(l)).lstrip("0")
[Editar] código modificado para manejar enteros con signo.
[Editar2] Aquí hay algunas cifras de tiempo de las diversas soluciones. bin es la función anterior, constantin_bin es de Constantin's answer y num_bin es la versión original. Por curiosidad, también probé una variante de tabla de búsqueda de 16 bits de la anterior (bin16 a continuación), y probé la función bin() integrada de Python3. Todos los tiempos fueron para 100000 ejecuciones usando un patrón de 01010101 bits.
Num Bits: 8 16 32 64 128 256
---------------------------------------------------------------------
bin 0.544 0.586 0.744 1.942 1.854 3.357
bin16 0.542 0.494 0.592 0.773 1.150 1.886
constantin_bin 2.238 3.803 7.794 17.869 34.636 94.799
num_bin 3.712 5.693 12.086 32.566 67.523 128.565
Python3's bin 0.079 0.045 0.062 0.069 0.212 0.201
Como se puede ver, procesar valores largos usando grandes trozos realmente vale la pena, pero no hay nada como el código C de bajo nivel de orden interna de python3 (que extrañamente parece consistentemente más rápido a 256 bits que 128!). Usar una tabla de búsqueda de 16 bits mejora las cosas, pero probablemente no valga la pena a menos que realmente lo necesite, ya que consume una gran cantidad de memoria y puede presentar un retraso de inicio pequeño pero no significativo para calcular previamente la tabla.
Gracias por la respuesta más o menos completa, que es utilizar 2.6 o 3.0 bin() functio n :) –