你需要调用locale.str
方法,而不是普通的str
构造函数。
import locale
locale.setlocale(locale.LC_NUMERIC,"ru_RU.utf8")
print locale.localeconv()
fv = 2.5
print locale.str(fv)
输出
{'mon_decimal_point': '', 'int_frac_digits': 127, 'p_sep_by_space': 127, 'frac_digits': 127, 'thousands_sep': '\xc2\xa0', 'n_sign_posn': 127, 'decimal_point': ',', 'int_curr_symbol': '', 'n_cs_precedes': 127, 'p_sign_posn': 127, 'mon_thousands_sep': '', 'negative_sign': '', 'currency_symbol': '', 'n_sep_by_space': 127, 'mon_grouping': [], 'p_cs_precedes': 127, 'positive_sign': '', 'grouping': [3, 3, 0]}
2,5
下面是一些代码,演示了一个简单的区域设置感知的打印函数。正如我在评论中提到的,通常最好在打印时提供明确的格式规范。当然,在非常简单的脚本和开发/调试期间,基本的
print a, b, c
形式很方便,但这种输出在除了最简单的情况之外使用时往往显得杂乱无序。
简单的
format_string % tuple_of_values
风格的格式化不具备区域设置感知能力。locale模块提供了一些函数(
format
&
format_string
),它们使用旧的
%
格式化协议。然而,在现代Python中,
%
风格的格式化正在被逐步淘汰,取而代之的是内置的
format
函数和
str.format
所支持的新风格的格式化。这些
format
函数为数字提供了本地感知的格式类型说明符:
n
;下面的代码说明了它的使用。
import locale
locale.setlocale(locale.LC_NUMERIC, "ru_RU.utf8")
def lprint(*args):
lstr = locale.str
print ' '.join([lstr(u) if isinstance(u, float) else str(u) for u in args])
lprint(1.25, 987654, 42.0, 2.33, u"Росси́я".encode('UTF-8'), 3.456)
print locale.format_string('%.2f %d %.3f %.3f %s %f', (1.25, 987654, 42.0, 2.33, u"Росси́я", 3.456))
print '{0:n} {1:n} {2:n} {3:n} {4:n} {5}'.format(1.25, 987654, 42.0, 2.33, 3.456, u"Росси́я".encode('UTF-8'))
输出(在设置为使用UTF-8编码的终端中)
1,25 987654 42 2,33 Россия 3,456
1,25 987654 42,000 2,330 Россия 3,456000
1,25 987 654 42 2,33 3,456 Россия
请注意,在第二行中,我们可以传递Unicode字符串对象,因为
locale.format_string
知道编码方式。在输出的最后一行中,数字987654会以千位分隔符打印出来,在俄罗斯语环境中,千位分隔符是一个空格。
如果您使用Python 2.7(或更高版本),那么
'{0:n} {1:n} {2:n} {3:n} {4:n} {5}'
格式字符串可以简化为
'{:n} {:n} {:n} {:n} {:n} {}'
。当然,在Python 3中,
print
语句已不再可用:它被
print
函数所取代;您可以在Python 2的后续版本中通过在任何其他
import
语句之前执行
from __future__ import print_function
来访问该函数。
print
语句。然而,在打印时提供明确的格式通常比依赖默认格式更好。我会在我的答案中添加一些示例。 - PM 2Ring