Python - фиксированный показатель в научной нотации?

Рассмотрим следующий фрагмент Python:

for ix in [0.02, 0.2, 2, 20, 200, 2000]:
  iss=str(ix) + "e9"
  isf=float(iss)
  print(iss + "\t=> " + ("%04.03e" % isf ) + " (" + str(isf) + ")")

Он генерирует следующий вывод:

0.02e9  => 2.000e+07 (20000000.0)
0.2e9   => 2.000e+08 (200000000.0)
2e9     => 2.000e+09 (2000000000.0)
20e9    => 2.000e+10 (20000000000.0)
200e9   => 2.000e+11 (2e+11)
2000e9  => 2.000e+12 (2e+12)

 

Мой вопрос - как-то можно "вернуться"? То есть:

2.000e+07 => 0.02e9 
2.000e+08 => 0.2e9
2.000e+09 => 2e9    
2.000e+10 => 20e9   
2.000e+11 => 200e9  
2.000e+12 => 2000e9 

... Я бы указал, что показатель экспоненты должен быть "e+09"; и затем любое число, которое я бросаю в эту гипотетическую функцию, возвращает значение числа в этом экспоненте? Можно ли в каждом случае указать нулевое заполнение как для целого, так и для десятичного числа? (т.е. 000.0200e9 и 020.0000e9)?

Ответ 1

Отформатируйте его самостоятельно (см. Формат спецификации Mini-Language):

for ix in [.02e9,.2e9,2e9,20e9,200e9,2000e9]:
    print('{:.3e} => {:0=8.3f}e9'.format(ix,ix/1e9))

Выход

2.000e+07 => 0000.020e9
2.000e+08 => 0000.200e9
2.000e+09 => 0002.000e9
2.000e+10 => 0020.000e9
2.000e+11 => 0200.000e9
2.000e+12 => 2000.000e9

Объяснение

{:0=8.3f} означает "нуль-pad, pad между знаком и номером, общая ширина поля 8, 3 места после десятичного формата с фиксированной точкой".

Ответ 2

Хорошо, получилось:

for ix in [0.02, 0.2, 2, 20, 200, 2000]:
  iss=str(ix) + "e9"
  isf=float(iss)
  isf2=isf/float("1e9")
  isf2s = ("%04.03f" % isf2) + "e9"
  print(iss + "\t=> " + ("%04.03e" % isf ) + " (" + str(isf) + ")" + " -> " + isf2s )

... дает:

0.02e9  => 2.000e+07 (20000000.0) -> 0.020e9
0.2e9   => 2.000e+08 (200000000.0) -> 0.200e9
2e9 => 2.000e+09 (2000000000.0) -> 2.000e9
20e9    => 2.000e+10 (20000000000.0) -> 20.000e9
200e9   => 2.000e+11 (2e+11) -> 200.000e9
2000e9  => 2.000e+12 (2e+12) -> 2000.000e9

Извините за размещение,
Ура!