为什么我在python中这样做时会得到以下错误:

>>> import locale
>>> print str( locale.getlocale() )
(None, None)
>>> locale.setlocale(locale.LC_ALL, 'de_DE')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/lib/python2.7/locale.py", line 531, in setlocale
    return _setlocale(category, locale)
locale.Error: unsupported locale setting

这也适用于其他地区,如fr或nl。我用的是Ubuntu 11.04。

更新:做以下事情没有任何结果:

dpkg-reconfigure locales
perl: warning: Setting locale failed.
perl: warning: Please check that your locale settings:
    LANGUAGE = (unset),
    LC_ALL = (unset),
    LC_CTYPE = "UTF-8",
    LANG = (unset)
    are supported and installed on your system.
perl: warning: Falling back to the standard locale ("C").
locale: Cannot set LC_CTYPE to default locale: No such file or directory
locale: Cannot set LC_ALL to default locale: No such file or directory

当前回答

在我看来,在python{,3}中设置本地语言环境最简单的方法是:

>>> import locale
>>> locale.setlocale(locale.LC_ALL, '')
'de_DE.UTF-8'

然后,区域感知的东西就可以工作了,如果你在一个像样的linux发行版上,应该也可以在其他操作系统的二进制发行版上工作(或者这是一个错误)。

>>> import datetime as dt
>>> print(dt.date.today().strftime("%A %d. %B %Y"))
Sonntag 11. Dezember 2016

其他回答

在我看来,在python{,3}中设置本地语言环境最简单的方法是:

>>> import locale
>>> locale.setlocale(locale.LC_ALL, '')
'de_DE.UTF-8'

然后,区域感知的东西就可以工作了,如果你在一个像样的linux发行版上,应该也可以在其他操作系统的二进制发行版上工作(或者这是一个错误)。

>>> import datetime as dt
>>> print(dt.date.today().strftime("%A %d. %B %Y"))
Sonntag 11. Dezember 2016

如果我理解正确的话,这里的主要错误来源是locale-name的确切语法。特别是在不同的发行版之间。 我在这里看到了不同的回答/评论:

de_DE.utf8
de_DE.UTF-8

虽然这对人类来说显然是一样的,但对你的标准确定性算法来说却不一样。

所以你可能会做这样的事情:

DESIRED_LOCALE=de
DESIRED_LOCALE_COUNTRY=DE
DESIRED_CODEPAGE_RE=\.[Uu][Tt][Ff].?8
if [ $(locale -a | grep -cE "${DESIRED_LOCALE}_${DESIRED_LOCALE_COUNTRY}${DESIRED_CODEPAGE_RE}") -eq 1 ]
then
    export LC_ALL=$(locale -a | grep -m1 -E "${DESIRED_LOCALE}_${DESIRED_LOCALE_COUNTRY}${DESIRED_CODEPAGE_RE}")
    export LANG=$LC_ALL
else
    echo "Not exactly one desired locale definition found: $(locale -a | grep -E "${DESIRED_LOCALE}_${DESIRED_LOCALE_COUNTRY}${DESIRED_CODEPAGE_RE}")" >&2
fi

更持久的解决方案是在命令:locale显示的输出中填充缺失的值

locale的输出是:

 $ locale
LANG=en_US.utf8
LANGUAGE=
LC_CTYPE="en_US.utf8"
LC_NUMERIC=es_ES.utf8
LC_TIME=es_ES.utf8
LC_COLLATE="en_US.utf8"
LC_MONETARY=es_ES.utf8
LC_MESSAGES="en_US.utf8"
LC_PAPER=es_ES.utf8
LC_NAME="en_US.utf8"
LC_ADDRESS="en_US.utf8"
LC_TELEPHONE="en_US.utf8"
LC_MEASUREMENT=es_ES.utf8
LC_IDENTIFICATION="en_US.utf8"
LC_ALL=

要填充缺失的值,请编辑~/。bashrc: (

 $ vim ~/.bashrc

在上面的命令之后添加以下行(假设您需要en_US。UTF-8为你的语言):

export LANGUAGE="en_US.UTF-8"
export LC_ALL="en_US.UTF-8"

如果这个文件是只读的,你将需要遵循GeekyBoy提到的步骤。Beco博士在Superuser中给出的答案有关于保存只读文件的细节。

保存文件后:

$ source ~/.bashrc

现在你不会再面临同样的问题了。

在Arch Linux上,我可以通过运行sudo locale-gen来解决这个问题

根据这个链接,输入如下命令进行求解:

出口LC_ALL = C