如何将浮动转换为“会计形式” -
100028282.23 --> 100,028,282.23
100028282 --> 100,028,282.00
有没有python方法可以做到这一点?
答案 0 :(得分:20)
作为beerbajay出色答案的替代方案,简单的字符串格式化工作在2.7+以上,无需导入:
>>> '{0:,.2f}'.format(24322.34)
'24,322.34'
答案 1 :(得分:14)
您可以使用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'
答案 2 :(得分:3)
对于货币应用程序, decimal 模块是浮点运算的不错选择。要使用逗号显示十进制浮点数,请参阅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))