[Python-Dev] str.ascii_lower
Martin v. Loewis
martin at v.loewis.de
Mon Dec 29 13:04:56 EST 2003
Jeff Epler wrote:
>>>>u"I".lower() # Python bug? (should be u'\u0131')
>
> u'i'
As Guido says: unicode.tolower is locale-inaware;
it uses the Unicode Consortium character properties
instead to determine the lower-case character.
>>>>"I".lower() # C library bug? (should be "\xc4\xb1")*
>
> 'I'
This is really a limitation of the C language, not of
the C library. The interface is
char tolower(char input);
so it can only accept and return a single char. Multi-byte
characters are not supported in that interface.
Traditionally, for characters that cannot be converted,
tolower returns its argument.
>>>>"I".lower() # (UTF-8 locale works properly in english)
>
> 'i'
This is because "i" is a single byte in UTF-8.
Regards,
Martin
More information about the Python-Dev
mailing list