13

我如何将浮点数转换为它的“会计表格”——

100028282.23 --> 100,028,282.23
100028282 --> 100,028,282.00

有没有这样做的python方法?

4

3 回答 3

23

作为beerbajay出色答案的替代方法,简单的字符串格式在 2.7+ 中有效,无需导入:

>>> '{0:,.2f}'.format(24322.34)
'24,322.34'
于 2012-05-20T21:32:22.373 回答
15

您可以使用该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'
于 2012-05-20T21:30:36.763 回答
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))
于 2012-05-20T21:40:41.180 回答