Path: csiph.com!newsfeed.hal-mli.net!feeder3.hal-mli.net!newsfeed.hal-mli.net!feeder1.hal-mli.net!feeder.erje.net!eu.feeder.erje.net!newsfeed.xs4all.nl!newsfeed5.news.xs4all.nl!xs4all!newsgate.cistron.nl!newsgate.news.xs4all.nl!post.news.xs4all.nl!not-for-mail Return-Path: X-Original-To: python-list@python.org Delivered-To: python-list@mail.python.org X-Spam-Status: OK 0.005 X-Spam-Evidence: '*H*': 0.99; '*S*': 0.00; 'python': 0.09; '(it': 0.09; 'encode': 0.09; 'cc:addr:python-list': 0.10; 'subject:error': 0.11; '(like': 0.15; 'encoding': 0.15; 'languages.': 0.15; '"import': 0.16; '(eg.': 0.16; 'benjamin': 0.16; 'codec': 0.16; 'example).': 0.16; 'subject:unicode': 0.16; 'unicode.': 0.16; 'wrote:': 0.17; 'unicode': 0.17; '>>>': 0.18; 'windows': 0.19; 'versions': 0.20; 'skip:" 40': 0.20; '"",': 0.22; '(on': 0.22; 'claimed': 0.22; 'cc:2**0': 0.23; 'programming': 0.23; "i've": 0.23; 'cc:no real name:2**0': 0.24; 'command': 0.24; 'machine': 0.24; 'tried': 0.25; 'cc:addr:python.org': 0.25; 'header:In-Reply-To:1': 0.25; '(most': 0.27; 'coding': 0.27; 'andrew': 0.27; 'message-id:@mail.gmail.com': 0.27; "doesn't": 0.28; 'correct': 0.28; '(possibly': 0.29; 'prints': 0.29; 'character': 0.29; 'worked': 0.30; 'received:209.85.215.46': 0.30; 'checked': 0.30; 'code': 0.31; 'point': 0.31; 'file': 0.32; 'traceback': 0.33; 'problem': 0.33; 'version': 0.34; "can't": 0.34; 'received:google.com': 0.34; 'so,': 0.35; 'subject:?': 0.35; 'received:209.85': 0.35; 'but': 0.36; '12,': 0.36; 'characters': 0.36; "didn't": 0.36; 'skip:p 20': 0.36; 'correctly': 0.37; 'does': 0.37; 'previous': 0.37; 'received:209': 0.37; 'subject:: ': 0.38; 'fact': 0.38; 'mean': 0.38; 'skip:o 20': 0.38; 'nothing': 0.38; 'page': 0.38; 'header:Received:5': 0.40; 'help': 0.40; 'think': 0.40; 'skip:u 10': 0.60; 'stand': 0.61; 'needing': 0.62; 'wish': 0.70; '(standard': 0.84; 'actually,': 0.84; 'novembre': 0.84; 'oscar': 0.84; '850': 0.91 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type:content-transfer-encoding; bh=seIWflEUEyjgpSg8svqNDajMvuMXU/6a35LDM8AGio8=; b=ulLcNg81Cjar5iPZ5gYd/Uv0wtZhGDpoW0ZQb4bqjqxo4VFNl+N4l/Spo4phE0LSzT jusJhhOFkDsZFh6mKaCWf90dZAruzaAMeQm8qC8UEhXPvLq3JoVqKoVfx7+VNaS9x/w4 6kMvuQrtn7D6rxC51JXRUmwG88D6cqrCWOae4XzXeXoPl/XIA0DwRr5RGW36/GlDQgxF PwXoASKtmzS0fiFNAJRhQu9SZmK9iuS9F6wU8l1nXJvwBvgR+WIFasflqsU2BKovFKdH LqbxVCierMGQEDsED0eh6oKn3bMd4Atn7+m83bSYvUUsMrSGhHpQGnIeOEzpD8usuohC oVUA== MIME-Version: 1.0 In-Reply-To: <65910cea-f145-409c-a579-9f0cda499546@googlegroups.com> References: <09a3d20b-5871-47f4-9218-df119698e405@m4g2000yqf.googlegroups.com> <509AF3EF.8050108@gmail.com> <65910cea-f145-409c-a579-9f0cda499546@googlegroups.com> Date: Thu, 8 Nov 2012 18:32:11 +0000 Subject: Re: Right solution to unicode error? From: Oscar Benjamin To: wxjmfauth@gmail.com Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: quoted-printable Cc: python-list@python.org X-BeenThere: python-list@python.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: General discussion list for the Python programming language List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Newsgroups: comp.lang.python Message-ID: Lines: 98 NNTP-Posting-Host: 2001:888:2000:d::a6 X-Trace: 1352399533 news.xs4all.nl 6868 [2001:888:2000:d::a6]:40351 X-Complaints-To: abuse@xs4all.nl Xref: csiph.com comp.lang.python:32970 On 8 November 2012 15:05, wrote: > Le jeudi 8 novembre 2012 15:07:23 UTC+1, Oscar Benjamin a =C3=A9crit : >> On 8 November 2012 00:44, Oscar Benjamin wr= ote: >> > On 7 November 2012 23:51, Andrew Berg wrot= e: >> >> On 2012.11.07 17:27, Oscar Benjamin wrote: >> >> >>> Are you using cmd.exe (standard Windows terminal)? If so, it does no= t >> >>> support unicode >> >> >> Actually, it does. Code page 65001 is UTF-8. I know that doesn't help >> >> the OP since Python versions below 3.3 don't support cp65001, but I >> >> think it's important to point out that the Windows command line syste= m >> >> (it is not unique to cmd) does in fact support Unicode. >> >> > I have tried to use code page 65001 and it didn't work for me even if >> > I did use a version of Python (possibly 3.3 alpha) that claimed to >> > support it. >> >> I stand corrected. I've just checked and codepage 65001 does work in >> cmd.exe (on this machine): >> >> O:\>chcp 65001 >> Active code page: 65001 >> >> O:\>Q:\tools\Python33\python -c print('abc\u2013def') >> abc-def >> >> O:\>Q:\tools\Python33\python -c print('\u03b1') >> =CE=B1 >> >> It would be a lot better though if it just worked straight away >> without me needing to set the code page (like the terminal in every >> other OS I use). > > It *WORKS* straight away. The problem is that > people do not wish to use unicode correctly > (eg. Mulder's example). > Read the point 1) and 4) in my previous post. > > Unicode and in general the coding of the characters > have nothing to do with the os's or programming languages. I don't know what you mean that it works "straight away". The default code page on my machine is cp850. O:\>chcp Active code page: 850 cp850 doesn't understand utf-8. It just prints garbage: O:\>Q:\tools\Python33\python -c "import sys; sys.stdout.buffer.write('\u03b1\n'.encode('utf-8'))" =E2=95=AC=E2=96=92 Using the correct encoding doesn't help: O:\>Q:\tools\Python33\python -c "import sys; sys.stdout.buffer.write('\u03b1\n'.encode('cp850'))" Traceback (most recent call last): File "", line 1, in File "Q:\tools\Python33\lib\encodings\cp850.py", line 12, in encode return codecs.charmap_encode(input,errors,encoding_map) UnicodeEncodeError: 'charmap' codec can't encode character '\u03b1' in position 0: character maps to O:\>Q:\tools\Python33\python -c "import sys; sys.stdout.buffer.write('\u03b1\n'.encode(sys.stdout.en coding))" Traceback (most recent call last): File "", line 1, in File "Q:\tools\Python33\lib\encodings\cp850.py", line 12, in encode return codecs.charmap_encode(input,errors,encoding_map) UnicodeEncodeError: 'charmap' codec can't encode character '\u03b1' in position 0: character maps to If I want the other characters to work I need to change the code page: O:\>chcp 65001 Active code page: 65001 O:\>Q:\tools\Python33\python -c "import sys; sys.stdout.buffer.write('\u03b1\n'.encode('utf-8'))" =CE=B1 O:\>Q:\tools\Python33\python -c "import sys; sys.stdout.buffer.write('\u03b1\n'.encode(sys.stdout.en coding))" =CE=B1 Oscar