A quanto mi risulta, si desidera solo la parte 'più significativa'. Per fare ciò, utilizzare floor(log10(abs(n)))
per ottenere il numero di cifre e quindi passare da lì. Qualcosa di simile, forse:
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])
Esecuzione della funzione di cui sopra per un po 'di numeri diversi:
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
Vorrei avere così tanti soldi. –
installa clisp e scrivi: '(formato t" ~ r "(parse-integer (read-line * standard-input *))) quindi usa il sottoprocesso per chiamare' clisp prettynum.cl 187.000.000.000.000' ... Anche se io solo ha chiesto un'alternativa http://stackoverflow.com/questions/3158132/is-there-a-python-version-of-lisps-format-r –
['python-ballpark'] (https://github.com/ debrouwere/python-ballpark) sembra essere progettato esattamente per quello che l'OP chiede. –