2016 ОБНОВЛЕНИЕ: Оказывается, это ошибка Python , поскольку, по крайней мере, 2013 год, очень вероятно, также и раньше, состоящий в том, что Python плохо реагирует на локали не-GNU - как в Mac OS X BSDs. Ошибка по-прежнему открыта по состоянию на сентябрь 2016 года и затрагивает все версии Python.
Если переменная окружения не установлена LANG
, скорее всего, у вас была либо переменная окружения LC_CTYPE
(переменная ключа), либо LC_ALL
(которая переопределяет, если установлена), установленная на UTF-8
, которая не является действительный язык OS X Воспроизвести достаточно с помощью /usr/bin/python
, поставляемого Apple, или с пользовательским питоном, как в вашем случае, который был собран с 10.6 SDK (возможно, также 10.5 SDK). Вы не сможете воспроизвести его таким образом с python.org; в настоящее время они построены с использованием 10.4 SDK, где API локали ведут себя по-разному.
$ unset LANG
$ env | grep LC_
$ export LC_CTYPE="UTF-8"
$ /usr/bin/python # Apple-supplied python
Python 2.6.1 (r261:67515, Jul 7 2009, 23:51:51)
[GCC 4.2.1 (Apple Inc. build 5646)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import locale ; locale.getdefaultlocale()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/System/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/locale.py", line 459, in getdefaultlocale
return _parse_localename(localename)
File "/System/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/locale.py", line 391, in _parse_localename
raise ValueError, 'unknown locale: %s' % localename
ValueError: unknown locale: UTF-8
^D
$ /usr/local/bin/python2.6 # python.org python
Python 2.6.4 (r264:75821M, Oct 27 2009, 19:48:32)
[GCC 4.0.1 (Apple Inc. build 5493)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import locale ; locale.getdefaultlocale()
(None, 'mac-roman')
>>>
EDIT:
Там может быть еще один кусок головоломки. Быстрый просмотр установленного мной bzr
2.0.1 показывает, что цитируемое вами сообщение должно отображаться только в том случае, если locale.getpreferredencoding()
поднимает locale.Error
. Это может произойти, если расширение python _locale.so
C не может быть загружено, и это может произойти, если на нем есть проблемы с правами доступа. Например, в настоящее время известно, что MacPorts имеет проблем с настройкой разрешений, если у вас настроен umask ; Я был сожжен этой проблемой сам. Проверьте разрешения _locale.so
в каталоге python lib/python2.5/lib-dynload
и убедитесь, что оно 755
. Полный путь для MacPorts должен быть:
/opt/local/Library/Frameworks/Python.framework/Versions/2.5/lib/python2.5/lib-dynload/