Por ejemplo, tengo la variable 3.545555555, que me gustaría truncar a solo 3.54.
Por ejemplo, tengo la variable 3.545555555, que me gustaría truncar a solo 3.54.
Respuestas:
Si lo desea para fines de visualización, use java.text.DecimalFormat
:
new DecimalFormat("#.##").format(dblVar);
Si lo necesita para los cálculos, utilice java.lang.Math
:
Math.floor(value * 100) / 100;
floor
para truncar solo funciona para valores positivos.
RoundingMode.DOWN
como RoudingMode.FLOOR
siempre vueltas hacia el infinito negativo.
DecimalFormat df = new DecimalFormat(fmt);
df.setRoundingMode(RoundingMode.DOWN);
s = df.format(d);
Consultar disponible RoundingMode
y DecimalFormat
.
DOWN
hecho tiene el efecto de truncamiento tanto para números positivos como negativos. Como se ve en la tabla de ejemplos en el doc .
Bit Old Forum, ninguna de las respuestas anteriores funcionó para valores positivos y negativos (me refiero al cálculo y solo para truncar sin redondeo). Desde el enlace Cómo redondear un número an decimales en Java
private static BigDecimal truncateDecimal(double x,int numberofDecimals)
{
if ( x > 0) {
return new BigDecimal(String.valueOf(x)).setScale(numberofDecimals, BigDecimal.ROUND_FLOOR);
} else {
return new BigDecimal(String.valueOf(x)).setScale(numberofDecimals, BigDecimal.ROUND_CEILING);
}
}
Este método funcionó bien para mí.
System.out.println(truncateDecimal(0, 2));
System.out.println(truncateDecimal(9.62, 2));
System.out.println(truncateDecimal(9.621, 2));
System.out.println(truncateDecimal(9.629, 2));
System.out.println(truncateDecimal(9.625, 2));
System.out.println(truncateDecimal(9.999, 2));
System.out.println(truncateDecimal(-9.999, 2));
System.out.println(truncateDecimal(-9.0, 2));
Resultados:
0.00
9.62
9.62
9.62
9.62
9.99
-9.99
-9.00
Tenga en cuenta primero que a double
es una fracción binaria y en realidad no tiene decimales.
Si necesita lugares decimales, use a BigDecimal
, que tiene un setScale()
método de truncamiento, o use DecimalFormat
para obtener un String
.
Si, por alguna razón, no desea utilizar a BigDecimal
, puede convertir su double
a int
para truncarlo.
Si desea truncar al lugar de los unos :
int
Al lugar de las Décimas :
int
double
Centésimas de lugar
Ejemplo:
static double truncateTo( double unroundedNumber, int decimalPlaces ){
int truncatedNumberInt = (int)( unroundedNumber * Math.pow( 10, decimalPlaces ) );
double truncatedNumber = (double)( truncatedNumberInt / Math.pow( 10, decimalPlaces ) );
return truncatedNumber;
}
En este ejemplo, decimalPlaces
sería el número de lugares DESPUÉS del lugar de las unidades al que desea ir, por lo que 1 redondearía al lugar de las décimas , 2 a las centésimas , y así sucesivamente (0 se redondea al lugar de las unidades y negativo uno a las decenas , etc.)
unroundedNumber
es lo suficientemente grande. Puede funcionar para el ejemplo de la pregunta, pero una solución general debería funcionar para cualquiera double
.
Formatear como una cadena y convertir de nuevo a doble creo que le dará el resultado que desea.
El valor doble no será round (), floor () o ceil ().
Una solución rápida podría ser:
String sValue = (String) String.format("%.2f", oldValue);
Double newValue = Double.parseDouble(sValue);
Puede utilizar el sValue para fines de visualización o el newValue para el cálculo.
Puede utilizar el objeto de clase NumberFormat para realizar la tarea.
// Creating number format object to set 2 places after decimal point
NumberFormat nf = NumberFormat.getInstance();
nf.setMaximumFractionDigits(2);
nf.setGroupingUsed(false);
System.out.println(nf.format(precision));// Assuming precision is a double type variable
Este es el método que utilizo:
double a=3.545555555; // just assigning your decimal to a variable
a=a*100; // this sets a to 354.555555
a=Math.floor(a); // this sets a to 354
a=a/100; // this sets a to 3.54 and thus removing all your 5's
Esto también se puede hacer:
a=Math.floor(a*100) / 100;
Quizás siguiendo:
double roundTwoDecimals(double d) {
DecimalFormat twoDForm = new DecimalFormat("#.##");
return Double.valueOf(twoDForm.format(d));
}
Una comprobación rápida es utilizar el método Math.floor. Creé un método para verificar un doble para dos o menos lugares decimales a continuación:
public boolean checkTwoDecimalPlaces(double valueToCheck) {
// Get two decimal value of input valueToCheck
double twoDecimalValue = Math.floor(valueToCheck * 100) / 100;
// Return true if the twoDecimalValue is the same as valueToCheck else return false
return twoDecimalValue == valueToCheck;
}
Tengo una versión ligeramente modificada de Mani .
private static BigDecimal truncateDecimal(final double x, final int numberofDecimals) {
return new BigDecimal(String.valueOf(x)).setScale(numberofDecimals, BigDecimal.ROUND_DOWN);
}
public static void main(String[] args) {
System.out.println(truncateDecimal(0, 2));
System.out.println(truncateDecimal(9.62, 2));
System.out.println(truncateDecimal(9.621, 2));
System.out.println(truncateDecimal(9.629, 2));
System.out.println(truncateDecimal(9.625, 2));
System.out.println(truncateDecimal(9.999, 2));
System.out.println(truncateDecimal(3.545555555, 2));
System.out.println(truncateDecimal(9.0, 2));
System.out.println(truncateDecimal(-9.62, 2));
System.out.println(truncateDecimal(-9.621, 2));
System.out.println(truncateDecimal(-9.629, 2));
System.out.println(truncateDecimal(-9.625, 2));
System.out.println(truncateDecimal(-9.999, 2));
System.out.println(truncateDecimal(-9.0, 2));
System.out.println(truncateDecimal(-3.545555555, 2));
}
Salida:
0.00
9.62
9.62
9.62
9.62
9.99
9.00
3.54
-9.62
-9.62
-9.62
-9.62
-9.99
-9.00
-3.54
Esto funcionó para mí:
double input = 104.8695412 //For example
long roundedInt = Math.round(input * 100);
double result = (double) roundedInt/100;
//result == 104.87
Personalmente, me gusta esta versión porque en realidad realiza el redondeo numérico, en lugar de convertirla en una cadena (o similar) y luego formatearla.
//if double_v is 3.545555555
String string_v= String.valueOf(double_v);
int pointer_pos = average.indexOf('.');//we find the position of '.'
string_v.substring(0, pointer_pos+2));// in this way we get the double with only 2 decimal in string form
double_v = Double.valueOf(string_v);//well this is the final result
Bueno, esto puede ser un poco incómodo, pero creo que puede resolver tu problema :)