-
-
Notifications
You must be signed in to change notification settings - Fork 30.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
bpo-10379: deprecate locale.format in lieu of locale.format_string #259
Changes from 12 commits
d0f9863
820e289
4cfd737
a08419f
4e24a3f
6097e47
04577c2
2039406
5b100b8
041349f
795aa65
8190fa9
7e0bfcf
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -76,16 +76,14 @@ Other Language Changes | |
====================== | ||
|
||
* More than 255 arguments can now be passed to a function, and a function can | ||
now have more than 255 parameters. | ||
(Contributed by Serhiy Storchaka in :issue:`12844` and :issue:`18896`.) | ||
now have more than 255 parameters. (Contributed by Serhiy Storchaka in | ||
:issue:`12844` and :issue:`18896`.) | ||
|
||
* :meth:`bytes.fromhex` and :meth:`bytearray.fromhex` now ignore all ASCII | ||
whitespace, not only spaces. | ||
(Contributed by Robert Xiao in :issue:`28927`.) | ||
whitespace, not only spaces. (Contributed by Robert Xiao in :issue:`28927`.) | ||
|
||
* :exc:`ImportError` now displays module name and module ``__file__`` path when | ||
``from ... import ...`` fails. | ||
(Contributed by Matthias Bussonnier in :issue:`29546`.) | ||
``from ... import ...`` fails. (Contributed by Matthias Bussonnier in :issue:`29546`.) | ||
|
||
|
||
New Modules | ||
|
@@ -97,25 +95,32 @@ New Modules | |
Improved Modules | ||
================ | ||
|
||
locale | ||
------ | ||
|
||
Added another argument *monetary* in :meth:`format_string` of :mod:`locale`. | ||
If *monetary* is true, the conversion uses monetary thousands separator and | ||
grouping strings. (Contributed by Garvit in :issue:`10379`.) | ||
|
||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Small nit: our convention appears to be to put the Contributed by as part of the paragraph when there's only one paragraph. Ends up formatted the same in html, but might as well make the ReST consistent as well. |
||
os | ||
-- | ||
|
||
Added support for :class:`bytes` paths in :func:`~os.fwalk`. | ||
(Contributed by Serhiy Storchaka in :issue:`28682`.) | ||
Added support for :class:`bytes` paths in :func:`~os.fwalk`. (Contributed by | ||
Serhiy Storchaka in :issue:`28682`.) | ||
|
||
unittest.mock | ||
------------- | ||
|
||
The :const:`~unittest.mock.sentinel` attributes now preserve their identity | ||
when they are :mod:`copied <copy>` or :mod:`pickled <pickle>`. | ||
(Contributed by Serhiy Storchaka in :issue:`20804`.) | ||
when they are :mod:`copied <copy>` or :mod:`pickled <pickle>`. (Contributed by | ||
Serhiy Storchaka in :issue:`20804`.) | ||
|
||
xmlrpc.server | ||
------------- | ||
|
||
:meth:`register_function` of :class:`xmlrpc.server.SimpleXMLRPCDispatcher` and | ||
its subclasses can be used as a decorator. | ||
(Contributed by Xiang Zhang in :issue:`7769`.) | ||
its subclasses can be used as a decorator. (Contributed by Xiang Zhang in | ||
:issue:`7769`.) | ||
|
||
urllib.parse | ||
------------ | ||
|
@@ -130,13 +135,13 @@ Optimizations | |
|
||
* Added two new opcodes: ``LOAD_METHOD`` and ``CALL_METHOD`` to avoid | ||
instantiation of bound method objects for method calls, which results | ||
in method calls being faster up to 20%. | ||
(Contributed by Yury Selivanov and INADA Naoki in :issue:`26110`.) | ||
in method calls being faster up to 20%. (Contributed by Yury Selivanov and | ||
INADA Naoki in :issue:`26110`.) | ||
|
||
* Fast implementation from standard C library is now used for functions | ||
:func:`~math.tgamma`, :func:`~math.lgamma`, :func:`~math.erf` and | ||
:func:`~math.erfc` in the :mod:`math` module. | ||
(Contributed by Serhiy Storchaka in :issue:`26121`.) | ||
:func:`~math.erfc` in the :mod:`math` module. (Contributed by Serhiy | ||
Storchaka in :issue:`26121`.) | ||
|
||
|
||
Build and C API Changes | ||
|
@@ -154,8 +159,8 @@ Build and C API Changes | |
``char *``. (Contributed by Serhiy Storchaka in :issue:`28761`.) | ||
|
||
* The result of :c:func:`PyUnicode_AsUTF8AndSize` and :c:func:`PyUnicode_AsUTF8` | ||
is now of type ``const char *`` rather of ``char *``. | ||
(Contributed by Serhiy Storchaka in :issue:`28769`.) | ||
is now of type ``const char *`` rather of ``char *``. (Contributed by Serhiy | ||
Storchaka in :issue:`28769`.) | ||
|
||
* Added functions :c:func:`PySlice_Unpack` and :c:func:`PySlice_AdjustIndices`. | ||
(Contributed by Serhiy Storchaka in :issue:`27867`.) | ||
|
@@ -169,6 +174,9 @@ Deprecated | |
``0x03050400`` and ``0x03060000`` (not including) or ``0x03060100`` or | ||
higher. (Contributed by Serhiy Storchaka in :issue:`27867`.) | ||
|
||
- Deprecated :meth:`format` from :mod:`locale`, use the :meth:`format_string` | ||
instead. (Contributed by Garvit in :issue:`10379`.) | ||
|
||
- Methods | ||
:meth:`MetaPathFinder.find_module() <importlib.abc.MetaPathFinder.find_module>` | ||
(replaced by | ||
|
@@ -181,8 +189,8 @@ Deprecated | |
by Matthias Bussonnier in :issue:`29576`) | ||
|
||
- Using non-integer value for selecting a plural form in :mod:`gettext` is | ||
now deprecated. It never correctly worked. | ||
(Contributed by Serhiy Storchaka in :issue:`28692`.) | ||
now deprecated. It never correctly worked. (Contributed by Serhiy Storchaka | ||
in :issue:`28692`.) | ||
|
||
|
||
Removed | ||
|
@@ -219,8 +227,8 @@ Changes in the Python API | |
|
||
* A format string argument for :meth:`string.Formatter.format` | ||
is now :ref:`positional-only <positional-only_parameter>`. | ||
Passing it as a keyword argument was deprecated in Python 3.5. | ||
(Contributed by Serhiy Storchaka in :issue:`29193`.) | ||
Passing it as a keyword argument was deprecated in Python 3.5. (Contributed | ||
by Serhiy Storchaka in :issue:`29193`.) | ||
|
||
* Attributes :attr:`~http.cookies.Morsel.key`, | ||
:attr:`~http.cookies.Morsel.value` and | ||
|
@@ -234,8 +242,8 @@ Changes in the Python API | |
``ClassDef`` AST nodes now have a new ``docstring`` field. | ||
The first statement in their body is not considered as a docstring | ||
anymore. ``co_firstlineno`` and ``co_lnotab`` of code object for class | ||
and module are affected by this change. | ||
(Contributed by INADA Naoki and Eugene Toder in :issue:`29463`.) | ||
and module are affected by this change. (Contributed by INADA Naoki and | ||
Eugene Toder in :issue:`29463`.) | ||
|
||
CPython bytecode changes | ||
------------------------ | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -17,6 +17,7 @@ | |
import collections | ||
from builtins import str as _builtin_str | ||
import functools | ||
import warnings | ||
|
||
# Try importing the _locale module. | ||
# | ||
|
@@ -180,19 +181,6 @@ def _strip_padding(s, amount): | |
_percent_re = re.compile(r'%(?:\((?P<key>.*?)\))?' | ||
r'(?P<modifiers>[-#0-9 +*.hlL]*?)[eEfFgGdiouxXcrs%]') | ||
|
||
def format(percent, value, grouping=False, monetary=False, *additional): | ||
"""Returns the locale-aware substitution of a %? specifier | ||
(percent). | ||
|
||
additional is for format strings which contain one or more | ||
'*' modifiers.""" | ||
# this is only for one-percent-specifier strings and this should be checked | ||
match = _percent_re.match(percent) | ||
if not match or len(match.group())!= len(percent): | ||
raise ValueError(("format() must be given exactly one %%char " | ||
"format specifier, %s not valid") % repr(percent)) | ||
return _format(percent, value, grouping, monetary, *additional) | ||
|
||
def _format(percent, value, grouping=False, monetary=False, *additional): | ||
if additional: | ||
formatted = percent % ((value,) + additional) | ||
|
@@ -217,10 +205,13 @@ def _format(percent, value, grouping=False, monetary=False, *additional): | |
formatted = _strip_padding(formatted, seps) | ||
return formatted | ||
|
||
def format_string(f, val, grouping=False): | ||
def format_string(f, val, grouping=False, monetary=False): | ||
"""Formats a string in the same way that the % formatting would use, | ||
but takes the current locale into account. | ||
Grouping is applied if the third parameter is true.""" | ||
|
||
Grouping is applied if the third parameter is true. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As long as we are editing this, I think there should be a blank line after the first sentence, before the 'Grouping' sentence. |
||
Conversion uses monetary thousands separator and grouping strings if | ||
forth parameter monetary is true.""" | ||
percents = list(_percent_re.finditer(f)) | ||
new_f = _percent_re.sub('%s', f) | ||
|
||
|
@@ -230,7 +221,7 @@ def format_string(f, val, grouping=False): | |
if perc.group()[-1]=='%': | ||
new_val.append('%') | ||
else: | ||
new_val.append(format(perc.group(), val, grouping)) | ||
new_val.append(_format(perc.group(), val, grouping, monetary)) | ||
else: | ||
if not isinstance(val, tuple): | ||
val = (val,) | ||
|
@@ -244,13 +235,27 @@ def format_string(f, val, grouping=False): | |
new_val.append(_format(perc.group(), | ||
val[i], | ||
grouping, | ||
False, | ||
monetary, | ||
*val[i+1:i+1+starcount])) | ||
i += (1 + starcount) | ||
val = tuple(new_val) | ||
|
||
return new_f % val | ||
|
||
def format(percent, value, grouping=False, monetary=False, *additional): | ||
"""Deprecated, use format_string instead.""" | ||
warnings.warn( | ||
"This method will be removed in a future version of Python." | ||
"Use 'locale.format_string()' instead.", | ||
DeprecationWarning, stacklevel=2 | ||
) | ||
|
||
match = _percent_re.match(percent) | ||
if not match or len(match.group())!= len(percent): | ||
raise ValueError(("format() must be given exactly one %%char " | ||
"format specifier, %s not valid") % repr(percent)) | ||
return _format(percent, value, grouping, monetary, *additional) | ||
|
||
def currency(val, symbol=True, grouping=False, international=False): | ||
"""Formats val according to the currency settings | ||
in the current locale.""" | ||
|
@@ -262,7 +267,7 @@ def currency(val, symbol=True, grouping=False, international=False): | |
raise ValueError("Currency formatting is not possible using " | ||
"the 'C' locale.") | ||
|
||
s = format('%%.%if' % digits, abs(val), grouping, monetary=True) | ||
s = _format('%%.%if' % digits, abs(val), grouping, monetary=True) | ||
# '<' and '>' are markers if the sign must be inserted between symbol and value | ||
s = '<' + s + '>' | ||
|
||
|
@@ -298,7 +303,7 @@ def currency(val, symbol=True, grouping=False, international=False): | |
|
||
def str(val): | ||
"""Convert float to string, taking the locale into account.""" | ||
return format("%.12g", val) | ||
return _format("%.12g", val) | ||
|
||
def delocalize(string): | ||
"Parses a string as a normalized number according to the locale settings." | ||
|
@@ -327,7 +332,7 @@ def atoi(string): | |
def _test(): | ||
setlocale(LC_ALL, "") | ||
#do grouping | ||
s1 = format("%d", 123456789,1) | ||
s1 = format_string("%d", 123456789,1) | ||
print(s1, "is", atoi(s1)) | ||
#standard formatting | ||
s1 = str(3.14) | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -364,6 +364,8 @@ Library | |
- bpo-29534: Fixed different behaviour of Decimal.from_float() | ||
for _decimal and _pydecimal. Thanks Andrew Nester. | ||
|
||
- bpo-10379: Deprecate locale.format in lue of locale.format_string | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Google says it's spelled 'lieu'. Also the entry should note that the monetary argument was added to format_string. So, how about "locale.format_string now supports the 'monetary' keyword argument, and locale.format is deprecated." |
||
|
||
- Issue #28556: Various updates to typing module: typing.Counter, typing.ChainMap, | ||
improved ABC caching, etc. Original PRs by Jelle Zijlstra, Ivan Levkivskyi, | ||
Manuel Krebber, and Łukasz Langa. | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The description of the monetary parameter should be added to the regular docs, and the version changed phrase should just say "the monetary keyword parameter was added"