Подтвердить что ты не робот

Странная ошибка python. что здесь происходит?

Итак, сегодня я перешел на bazaar 2.0.2, и я начал получать это сообщение (я на снежном леопарде, кстати):

bzr: warning: unknown locale: UTF-8
  Could not determine what text encoding to use.
  This error usually means your Python interpreter
  doesn't support the locale set by $LANG (en_US.UTF-8)
  Continuing with ascii encoding.

очень странно, поскольку мой LANG фактически пуст. Подобная вещь случается, когда я пытаюсь возиться с языковым модулем

Python 2.5.4 (r254:67916, Nov 30 2009, 14:09:22) 
[GCC 4.3.4] 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 "/Users/sbo/runtimes/lib/python2.5/locale.py", line 443, in getdefaultlocale
    return _parse_localename(localename)
  File "/Users/sbo/runtimes/lib/python2.5/locale.py", line 375, in _parse_localename
    raise ValueError, 'unknown locale: %s' % localename
ValueError: unknown locale: UTF-8

экспорт LANG не помогает

[email protected]:~ $ export LANG=en_US.UTF-8
[email protected]:~ $ bzr
bzr: warning: unknown locale: UTF-8
  Could not determine what text encoding to use.
  This error usually means your Python interpreter
  doesn't support the locale set by $LANG (en_US.UTF-8)
  Continuing with ascii encoding.

Однако это решило проблему

[email protected]:~ $ export LANG=en_US.UTF-8
[email protected]:~ $ export LC_ALL=en_US.UTF-8

Python 2.5.4 (r254:67916, Nov 30 2009, 14:09:22) 
[GCC 4.3.4] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import locale
>>> locale.getdefaultlocale()
('en_US', 'UTF8')

Не могли бы вы объяснить, что происходит здесь, для лучшей googlability?

4b9b3361

Ответ 1

2016 ОБНОВЛЕНИЕ: Оказывается, что это ошибка Python, по крайней мере, с 2013 года, вероятно, и раньше, состоящая в том, что Python не реагирует хорошо к не-GNU-локалам - как и в Mac OS X и BSD. Ошибка по-прежнему открыта по состоянию на сентябрь 2016 года и затрагивает каждую версию Python.


Если не было набора переменных среды LANG, скорее всего, у вас была либо переменная окружения LC_CTYPE (ключевая переменная), либо LC_ALL (которая переопределяет, если установлена), а переменная окружения UTF-8, которая не является действительный язык OS X. Достаточно легко воспроизвести поставляемый Apple /usr/bin/python или с помощью специального python, как в вашем случае, который был построен с 10.6 SDK (вероятно, также 10.5 SDK). Вы не сможете воспроизвести его с помощью python.org python; они в настоящее время построены с 10.4 SDK, где API-интерфейсы locale ведут себя по-разному.

$ 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/

Ответ 2

Это проблема Mac OS X. Чтобы увидеть настройки локали, запустите locale в терминале. locale -a должен отображать все локали, которые вы определили (которые вы можете использовать в качестве аргумента для LC_ALL).

Обратите внимание, что LC_ALL и другие переменные LC_* имеют приоритет над LANG, если они определены.

Ответ 3

Я столкнулся с той же проблемой. Когда я побежал locale, я заметил, что LANG и LC_ALL не установлены. Поэтому я исправил это, добавив следующие строки в файл .bash_profile:

export LC_ALL=en_US.UTF-8
export LANG=en_US.UTF-8

Затем я просто запустил:

source ~/.bash_profile 

И эта проблема была исправлена ​​после этого на моем Mac.