2012-05-20 28 views
10

我将如何转换成浮动的“会计报表” -转换浮到逗号分隔的字符串

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

是否存在,这是否一个Python的方法?

+6

用于货币金额作为浮动可能不是摆在首位这么好的。 – NPE

回答

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' 
+0

太棒了,谢谢! – David542

18

作为beerbajay优秀答案的替代方案呃,简单的字符串格式化可在2.7或更高,而无需进口:

>>> '{0:,.2f}'.format(24322.34) 
'24,322.34' 
3

对于货币的应用,小数模块是浮点运算是不错的选择。要使用逗号显示小数花车,看到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)) 
相关问题