|
|
|
|
[Python] Utf-8 une bonne fois pour toutes
Dernière réponse le 25 oct 2005 à 15:18:30 kilian, le 25 oct 2005 à 11:30:23Bonjour,
J'ai un script qui repertorie les valeurs dans la base de registres.
Lorsque python trouve un valeur entiere il récupère la valeure en tant qu'entiere.
Mais j'ai besoin de concatenatener le nom de la clé et la valeur donc je convertis parfois la valeur en une chaine avec str()
Mais str() tente de convertir en ascii, donc quand il bute sur une valeur supérieure à 127, j'ai une erreur.
Ex:
UnicodeDecodeError: 'ascii' codec can't decode byte 0x80 in position 3: ordinal not in range(128)
J'ai essayé unicode() mais unicode n'ncode que des chaines. Même chose avec encode("utf-8). D'ailleurs je préfèrerais de l'utf-8.
Pensez vous qu'il y ait une manière pour que str() transforme un entier en une chaine encodée en utf-8 ? Ou y a t'il une fonction que puisse faire ça...?
Merci d'avance.
Configuration: Python 2.4.2
UnicodeDecodeError: 'ascii' codec can't decode byte 0x80 in position 3: ordinal not in range(128)
|
Pour écrire un fichier UTF-8, par exemple:
#!/usr/bin/python # -*- coding: iso-8859-1 -*- import codecs chaine = "Le vélo dans le près." out = file( "monfichier.txt", "w" ) out.write( codecs.BOM_UTF8 ) out.write( chaine) out.close() Comme tu peux voir, il n'y a aucune conversion à faire sur 'chaine' car Python utilise déjà en interne Unicode (et il n'a donc aucun difficulté à l'écrire en UTF-8 dans le fichier.) |
J'ai chopé un des endroits ou ça coince.
print value[0] print value[1] value[0] + value[1] Affichage: CrÙatures 0 80 114 32 0 5 39 2 ensuite le value[0] + value[1] pour tester la concatenation donne ceci: File "list_files.py", line 259, in enum_tree value[0] + value[1] UnicodeDecodeError: 'ascii' codec can't decode byte 0xe9 in position 2: ordinal not in range(128) Y'aurait il un soucis si l'un est en ascci et l'autre en unicode par exemple? |
Alors en fait, je n'arrive pas à convertir value[0] en unicode.
value[0]=unicode(value[0]) UnicodeDecodeError: 'ascii' codec can't decode byte 0xe9 in position 2: ordinal not in range(128) En l'occurence value[0] c'est crÙatures Sachant que c'est en fait un accent aigu sur le U et non pas grave (je trouve pas l'accent aigu sur le clavier ici)... En tout cas on dirait que c'est bien de ce caractère qu'il s'agit (position 2) Bizzare... |
Donc le "transtypage" se fait car je n'ai pas d'erreur au moment du formatage avec "%s", je peux même afficher value[0] avec print. Mais dés qu'il faut lui faire une opération de conversion (unicode ou utf-8), une concatenation c'est comme s'il se rendait compte soudain qu'il comptait un intrus dans ses rangs..... |

