[Python-ideas] Rough draft: Proposed format specifier for a thousands separator (discussion moved from python-dev)

Eric Smith eric at trueblade.com
Fri Mar 13 01:08:23 CET 2009


Raymond Hettinger wrote:
> Whoa guys!  I think you're treading very far away from and rejecting the 
> whole idea of PEP 3101 which was to be the one ring to bind them all with
> format(obj, fmt) having just two arguments and doing nothing but
> passing them on to obj.__fmt__() which would be responsible for
> parsing a format string.

I completely agree. That's why I said "But this is all orthogonal to the 
str.format() discussion." I meant "orthogonal" in the "unrelated" sense.

I'm completely on board with your PEP 378 as a simple way just to get 
some simple formatting into numbers.

> Also,even  if you wanted a flexible clear separate tool just for number
> formatting, I don't think keyword arguments are the way to go.
> That is a somewhat heavy approach with limited flexibility.
> The research in PEP 378 shows that for languages needing
> fine control and extreme versatility in formatting, some kind
> of picture string is the way to go.  MS Excel is a champ
> at number/date formatting strings:   #,##0 and whatnot.
> The allow negatives to have placeholders, trailing minus signs,
> parentheses, etc.  Columns can be aligned neating, any type
> of padding can be used, any type of separator may be specified.
> The COBOL picture statements also offer flexibility and clarity.
> Mini-languages of some sort beat the heck out of functions
> with a zillion optional arguments.

I think picture based is okay and has its place, but a routine like my 
proposed format_number (which I know is a bad name) is really the heavy 
lifter for all locale-based number formatting. Decimal shouldn't really 
have to completely reimplement locale-based formatting, especially when 
it already exists in the core. I just want to expose it.

Eric.





More information about the Python-ideas mailing list