Вы можете использовать следующий метод утилиты -
public static double round(double valueToRound, int numberOfDecimalPlaces)
{
double multipicationFactor = Math.pow(10, numberOfDecimalPlaces);
double interestedInZeroDPs = valueToRound * multipicationFactor;
return Math.round(interestedInZeroDPs) / multipicationFactor;
}
Взгляните на PEP-238 : изменение оператора разделения
Оператор // будет иметь возможность запросить разделение по полу однозначно.
< / BLOCKQUOTE>
В принятом ответе уже упоминается PEP 238 . Я просто хочу добавить быстрый взгляд за кулисы для тех, кто интересуется тем, что происходит, не читая весь PEP.
Python отображает такие операторы, как +
, -
, *
и /
к специальным функциям, например, a + b
эквивалентен
a.__add__(b)
Что касается деления в Python 2, по умолчанию используется только /
, который отображается на __div__
, и результат зависит от типов ввода (например, int
, float
).
В Python 2.2 была введена функция __future__
division
, которая изменила семантику деления следующим образом (TL; DR из PEP 238):
/
отображается на __truediv__
, который должен «возвращать разумную аппроксимацию математического результата деления» (цитата из PEP 238) //
отображается на __floordiv__
, которая должна возвращаться польский результат /
С Python 3.0 изменения PEP 238 стали поведением по умолчанию, и в объектной модели Python не существует особого метода __div__
.
Если вы хотите использовать тот же код в Python 2 и Python 3, используйте
from __future__ import division
и придерживайтесь семантики PEP 238 /
и //
.
Надеюсь, что это может помочь кому-то мгновенно.
В Python 2.7: По умолчанию оператор разделения возвращает целочисленный вывод .
blockquote>, чтобы получить результат в double multiple 1.0 для «divend или divisor»
100/35 => 2 #(Expected is 2.857142857142857) (100*1.0)/35 => 2.857142857142857 100/(35*1.0) => 2.857142857142857
В Python 3
blockquote>// => used for integer output / => used for double output 100/35 => 2.857142857142857 100//35 => 2 100.//35 => 2.0 # floating-point result if divsor or dividend real
public abstract IBox createBox();
. [/g0]