Моя цель - просто преобразовать строку, такую как "1.2", в научную нотацию без дополнительной точности. Проблема в том, что я всегда получаю лишние 0 в конце моего вывода.
>>> input = "1.2"
>>> print '{:e}'.format(float(input))
1.200000e+00
Я пытаюсь выяснить, как получить только 1.2e+00
. Я понимаю, что могу указать точность в своем заявлении о формате, но я не хочу излишне урезать длинные строки. Я просто хочу подавить тренировки 0s.
Я попытался использовать Decimal.normalize(), который работает во всех случаях, кроме случаев, когда e < 2.
>>> print Decimal("1.2000e+4").normalize()
1.2E+4
>>> print Decimal("1.2000e+1").normalize()
12
Так что лучше, если я не хочу 12, я хочу 1.2e + 1.: P
Любые предложения будут очень благодарны!
Edit: Чтобы уточнить, входное значение уже округлено соответствующим образом до заданной длины, которая теперь неизвестна. Я пытаюсь избежать пересчета соответствующей точности форматирования.
В принципе, я мог бы иметь входные значения "1.23" и "1234.56", которые должны отображаться как "1.23e + 0" и "1.23456e + 3".
Мне может потребоваться просто проверить, как долго вводится строка ввода и использовать это, чтобы указать точность вручную, но я хотел проверить и убедиться, что я просто не пропустил что-то, что могло бы просто предотвратить экспоненциальный формат от произвольного добавления 0s.