[1.8.x] Fixed #24181 -- Fixed multi-char THOUSAND_SEPARATOR insertion
Report and original patch by Kay Cha.
Backport of 540ca563de
from master.
This commit is contained in:
parent
edbf6de753
commit
b44a56c308
|
@ -47,7 +47,7 @@ def format(number, decimal_sep, decimal_pos=None, grouping=0, thousand_sep='',
|
||||||
int_part_gd = ''
|
int_part_gd = ''
|
||||||
for cnt, digit in enumerate(int_part[::-1]):
|
for cnt, digit in enumerate(int_part[::-1]):
|
||||||
if cnt and not cnt % grouping:
|
if cnt and not cnt % grouping:
|
||||||
int_part_gd += thousand_sep
|
int_part_gd += thousand_sep[::-1]
|
||||||
int_part_gd += digit
|
int_part_gd += digit
|
||||||
int_part = int_part_gd[::-1]
|
int_part = int_part_gd[::-1]
|
||||||
return sign + int_part + dec_part
|
return sign + int_part + dec_part
|
||||||
|
|
|
@ -26,6 +26,9 @@ class TestNumberFormat(TestCase):
|
||||||
self.assertEqual(nformat('1234', '.', grouping=2, thousand_sep=',',
|
self.assertEqual(nformat('1234', '.', grouping=2, thousand_sep=',',
|
||||||
force_grouping=True), '12,34')
|
force_grouping=True), '12,34')
|
||||||
self.assertEqual(nformat('-1234.33', '.', decimal_pos=1), '-1234.3')
|
self.assertEqual(nformat('-1234.33', '.', decimal_pos=1), '-1234.3')
|
||||||
|
self.assertEqual(nformat('10000', '.', grouping=3,
|
||||||
|
thousand_sep='comma', force_grouping=True),
|
||||||
|
'10comma000')
|
||||||
|
|
||||||
def test_large_number(self):
|
def test_large_number(self):
|
||||||
most_max = ('{}179769313486231570814527423731704356798070567525844996'
|
most_max = ('{}179769313486231570814527423731704356798070567525844996'
|
||||||
|
|
Loading…
Reference in New Issue