latin-1 a ascii

Tengo una cadena Unicode con caracteres latinos acentuados, p. Ej.

n=unicode('Wikipédia, le projet d’encyclopédie','utf-8')

Quiero convertirlo en simple ascii, es decir, 'Wikipedia, le projet dencyclopedie', por lo que debería eliminarse todo lo agudo / acento, cedilla, etc.

¿Cuál es la forma más rápida de hacerlo, ya que era necesario hacerlo para hacer coincidir una larga lista desplegable de autocompletado?

Conclusión: Como uno de mis criterios es la velocidad, el registro de Lennart en 'su propio controlador de errores para codificación / decodificación Unicode' da el mejor resultado (vea la respuesta de Alex), la diferencia de velocidad aumenta a medida que más y más caracteres son latinos.

Aquí está la tabla de traducción que estoy usando, también el controlador de errores modificado, ya que debe ocuparse de toda la gama de caracteres no codificados de error.start a error.end

# -*- coding: utf-8 -*-
import codecs

"""
This is more of visual translation also avoiding multiple char translation
e.g. £ may be written as {pound}
"""
latin_dict = {
u"¡": u"!", u"¢": u"c", u"£": u"L", u"¤": u"o", u"¥": u"Y",
u"¦": u"|", u"§": u"S", u"¨": u"`", u"©": u"c", u"ª": u"a",
u"«": u"<<", u"¬": u"-", u"­": u"-", u"®": u"R", u"¯": u"-",
u"°": u"o", u"±": u"+-", u"²": u"2", u"³": u"3", u"´": u"'",
u"µ": u"u", u"¶": u"P", u"·": u".", u"¸": u",", u"¹": u"1",
u"º": u"o", u"»": u">>", u"¼": u"1/4", u"½": u"1/2", u"¾": u"3/4",
u"¿": u"?", u"À": u"A", u"Á": u"A", u"Â": u"A", u"Ã": u"A",
u"Ä": u"A", u"Å": u"A", u"Æ": u"Ae", u"Ç": u"C", u"È": u"E",
u"É": u"E", u"Ê": u"E", u"Ë": u"E", u"Ì": u"I", u"Í": u"I",
u"Î": u"I", u"Ï": u"I", u"Ð": u"D", u"Ñ": u"N", u"Ò": u"O",
u"Ó": u"O", u"Ô": u"O", u"Õ": u"O", u"Ö": u"O", u"×": u"*",
u"Ø": u"O", u"Ù": u"U", u"Ú": u"U", u"Û": u"U", u"Ü": u"U",
u"Ý": u"Y", u"Þ": u"p", u"ß": u"b", u"à": u"a", u"á": u"a",
u"â": u"a", u"ã": u"a", u"ä": u"a", u"å": u"a", u"æ": u"ae",
u"ç": u"c", u"è": u"e", u"é": u"e", u"ê": u"e", u"ë": u"e",
u"ì": u"i", u"í": u"i", u"î": u"i", u"ï": u"i", u"ð": u"d",
u"ñ": u"n", u"ò": u"o", u"ó": u"o", u"ô": u"o", u"õ": u"o",
u"ö": u"o", u"÷": u"/", u"ø": u"o", u"ù": u"u", u"ú": u"u",
u"û": u"u", u"ü": u"u", u"ý": u"y", u"þ": u"p", u"ÿ": u"y", 
u"’":u"'"}

def latin2ascii(error):
    """
    error is  protion of text from start to end, we just convert first
    hence return error.start+1 instead of error.end
    """
    return latin_dict[error.object[error.start]], error.start+1

codecs.register_error('latin2ascii', latin2ascii)

if __name__ == "__main__":
    x = u"¼ éíñ§ÐÌëÑ » ¼ ö ® © ’"
    print x
    print x.encode('ascii', 'latin2ascii')

Porque vuelvoerror.start + 1:

el objeto de error devuelto puede tener varios caracteres, y convertimos solo el primero de estos, p. si agregoprint error.start, error.end a error la salida del manejador es

¼ éíñ§ÐÌëÑ » ¼ ö ® © ’
0 1
2 10
3 10
4 10
5 10
6 10
7 10
8 10
9 10
11 12
13 14
15 16
17 18
19 20
21 22
1/4 einSDIeN >> 1/4 o R c '

así que en la segunda línea obtenemos los caracteres del 2 al 10, pero convertimos solo el 2 por lo tanto, devolvemos 3 como punto de continuación, si devolvemos el error.

¼ éíñ§ÐÌëÑ » ¼ ö ® © ’
0 1
2 10
11 12
13 14
15 16
17 18
19 20
21 22
1/4 e >> 1/4 o R c '

Como podemos ver, 2-10 porciones han sido reemplazadas por una sola charla. por supuesto, sería más rápido codificar todo el rango de una sola vez y devolver el error.end, pero para fines de demostración lo he mantenido simple.

verhttp://docs.python.org/library/codecs.html#codecs.register_error para más detalles

Respuestas a la pregunta(6)

Su respuesta a la pregunta