我将如何转换成浮动的“会计报表” -转换浮到逗号分隔的字符串
100028282.23 --> 100,028,282.23
100028282 --> 100,028,282.00
是否存在,这是否一个Python的方法?
我将如何转换成浮动的“会计报表” -转换浮到逗号分隔的字符串
100028282.23 --> 100,028,282.23
100028282 --> 100,028,282.00
是否存在,这是否一个Python的方法?
可以使用locale.format()
功能来做到这一点:
>>> import locale
>>> locale.setlocale(locale.LC_ALL, 'en_US.utf8')
'en_US.utf8'
>>> locale.format("%.2f", 100028282.23, grouping=True)
'100,028,282.23'
请注意,你必须给精度:%.2f
或者您可以使用locale.currency()
功能,遵循LC_MONETARY
设置:
>>> locale.currency(100028282.23)
'$100028282.23'
太棒了,谢谢! – David542
作为beerbajay优秀答案的替代方案呃,简单的字符串格式化可在2.7或更高,而无需进口:
>>> '{0:,.2f}'.format(24322.34)
'24,322.34'
对于货币的应用,小数模块是浮点运算是不错的选择。要使用逗号显示小数花车,看到moneyfmt配方:
def moneyfmt(value, places=2, curr='', sep=',', dp='.',
pos='', neg='-', trailneg=''):
"""Convert Decimal to a money formatted string.
places: required number of places after the decimal point
curr: optional currency symbol before the sign (may be blank)
sep: optional grouping separator (comma, period, space, or blank)
dp: decimal point indicator (comma or period)
only specify as blank when places is zero
pos: optional sign for positive numbers: '+', space or blank
neg: optional sign for negative numbers: '-', '(', space or blank
trailneg:optional trailing minus indicator: '-', ')', space or blank
>>> d = Decimal('-1234567.8901')
>>> moneyfmt(d, curr='$')
'-$1,234,567.89'
>>> moneyfmt(d, places=0, sep='.', dp='', neg='', trailneg='-')
'1.234.568-'
>>> moneyfmt(d, curr='$', neg='(', trailneg=')')
'($1,234,567.89)'
>>> moneyfmt(Decimal(123456789), sep=' ')
'123 456 789.00'
>>> moneyfmt(Decimal('-0.02'), neg='<', trailneg='>')
'<0.02>'
"""
q = Decimal(10) ** -places # 2 places --> '0.01'
sign, digits, exp = value.quantize(q).as_tuple()
result = []
digits = map(str, digits)
build, next = result.append, digits.pop
if sign:
build(trailneg)
for i in range(places):
build(next() if digits else '0')
build(dp)
if not digits:
build('0')
i = 0
while digits:
build(next())
i += 1
if i == 3 and digits:
i = 0
build(sep)
build(curr)
build(neg if sign else pos)
return ''.join(reversed(result))
用于货币金额作为浮动可能不是摆在首位这么好的。 – NPE