lo que tengo entendido, sólo desea la parte 'más importante'. Para hacerlo, use floor(log10(abs(n)))
para obtener el número de dígitos y luego vaya desde allí. Algo como esto, tal vez:
import math
millnames = ['',' Thousand',' Million',' Billion',' Trillion']
def millify(n):
n = float(n)
millidx = max(0,min(len(millnames)-1,
int(math.floor(0 if n == 0 else math.log10(abs(n))/3))))
return '{:.0f}{}'.format(n/10**(3 * millidx), millnames[millidx])
Ejecución de la función anterior para un montón de diferentes números:
for n in (1.23456789 * 10**r for r in range(-2, 19, 1)):
print('%20.1f: %20s' % (n,millify(n)))
0.0: 0
0.1: 0
1.2: 1
12.3: 12
123.5: 123
1234.6: 1 Thousand
12345.7: 12 Thousand
123456.8: 123 Thousand
1234567.9: 1 Million
12345678.9: 12 Million
123456789.0: 123 Million
1234567890.0: 1 Billion
12345678900.0: 12 Billion
123456789000.0: 123 Billion
1234567890000.0: 1 Trillion
12345678900000.0: 12 Trillion
123456789000000.0: 123 Trillion
1234567890000000.0: 1235 Trillion
12345678899999998.0: 12346 Trillion
123456788999999984.0: 123457 Trillion
1234567890000000000.0: 1234568 Trillion
Ojalá tuviera tanto dinero. –
instale clisp y escriba esto: '(format t" ~ r "(parse-integer (read-line * standard-input *)))' luego use subprocess para llamar a 'clisp prettynum.cl 187,000,000,000,000' ... Aunque yo solo preguntó sobre una alternativa http://stackoverflow.com/questions/3158132/is-there-a-python-version-of-lisps-format-r –
['python-ballpark'] (https://github.com/ debrouwere/python-ballpark) parece estar diseñado exactamente para lo que pide OP. –