保留兩位小數{java
方法一:{ide
double c=3.154215;.net
java.text.DecimalFormat myformat=new java.text.DecimalFormat("0.00");code
String str = myformat.format(c);
}orm
方式二:{blog
java.text.DecimalFormat df =new java.text.DecimalFormat("#.00");
df.format(你要格式化的數字);ip
例:new java.text.DecimalFormat("#.00").format(3.1415926)ci
#.00 表示兩位小數 #.0000四位小數 以此類推...
}get
方式三:{it
double d = 3.1415926;
String result = String .format("%.2f");
%.2f %. 表示 小數點前任意位數 2 表示兩位小數 格式後的結果爲f 表示浮點型
}
}
四捨五入 {
double f = 111231.5585;
BigDecimal b = new BigDecimal(f);
//保留2位小數
double f1 = b.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
}
[java] view plain copy
- public class PreciseCompute {
- //默認除法運算精度
- private static final int DEF_DIV_SCALE = 10;
-
- /**
- * 提供精確的加法運算。
- * @param v1 被加數
- * @param v2 加數
- * @return 兩個參數的和
- */
-
- public static double add(double v1, double v2) {
- BigDecimal b1 = new BigDecimal(Double.toString(v1));
- BigDecimal b2 = new BigDecimal(Double.toString(v2));
- return b1.add(b2).doubleValue();
- }
-
- /**
- * 提供精確的減法運算。
- * @param v1 被減數
- * @param v2 減數
- * @return 兩個參數的差
- */
-
- public static double sub(double v1, double v2) {
- BigDecimal b1 = new BigDecimal(Double.toString(v1));
- BigDecimal b2 = new BigDecimal(Double.toString(v2));
- return b1.subtract(b2).doubleValue();
- }
-
- /**
- * 提供精確的乘法運算。
- * @param v1 被乘數
- * @param v2 乘數
- * @return 兩個參數的積
- */
- public static double mul(double v1, double v2) {
- BigDecimal b1 = new BigDecimal(Double.toString(v1));
- BigDecimal b2 = new BigDecimal(Double.toString(v2));
- return b1.multiply(b2).doubleValue();
- }
-
- /**
- * 提供(相對)精確的除法運算,當發生除不盡的狀況時,精確到
- * 小數點之後10位,之後的數字四捨五入。
- * @param v1 被除數
- * @param v2 除數
- * @return 兩個參數的商
- */
-
- public static double div(double v1, double v2) {
- return div(v1, v2, DEF_DIV_SCALE);
- }
-
- /**
- * 提供(相對)精確的除法運算。當發生除不盡的狀況時,由scale參數指
- * 定精度,之後的數字四捨五入。
- * @param v1 被除數
- * @param v2 除數
- * @param scale 表示表示須要精確到小數點之後幾位。
- * @return 兩個參數的商
- */
- public static double div(double v1, double v2, int scale) {
- if (scale < 0) {
- throw new IllegalArgumentException(
- "The scale must be a positive integer or zero");
- }
- BigDecimal b1 = new BigDecimal(Double.toString(v1));
- BigDecimal b2 = new BigDecimal(Double.toString(v2));
- return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
- }
-
- /**
- * 提供精確的小數位四捨五入處理。
- * @param v 須要四捨五入的數字
- * @param scale 小數點後保留幾位
- * @return 四捨五入後的結果
- */
- public static double round(double v, int scale) {
- if (scale < 0) {
- throw new IllegalArgumentException(
- "The scale must be a positive integer or zero");
- }
- BigDecimal b = new BigDecimal(Double.toString(v));
- BigDecimal ne = new BigDecimal("1");
- return b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
- }
- }
my code:
[java] view plain copy
- private BigDecimal formatComma2BigDecimal(Object obj) {
- String val = String.valueOf(obj);
- if (val == null)
- return new BigDecimal("0.00");
-
- val = val.replaceAll(",", "");
- if (!isNumber(val))
- return new BigDecimal("0.00");
-
- BigDecimal decimal = new BigDecimal(val);
- decimal = decimal.setScale(2, RoundingMode.HALF_UP);
-
- return decimal;
-
- }
- private String formatCommaAnd2Point(Object obj) {
- BigDecimal decimal = formatComma2BigDecimal(obj);
-
- DecimalFormat df = new DecimalFormat("#,###.00");
- String decimalStr = df.format(decimal).equals(".00")?"0.00":df.format(decimal);
- if(decimalStr.startsWith(".")){
- decimalStr = "0"+decimalStr;
- }
- return decimalStr;
- }
- private boolean isDouble(String value) {
- try {
- Double.parseDouble(value);
- if (value.contains("."))
- return true;
- return false;
- } catch (NumberFormatException e) {
- return false;
- }
- }
- private boolean isInteger(String value) {
- try {
- Integer.parseInt(value);
- return true;
- } catch (NumberFormatException e) {
- return false;
- }
- }
- private boolean isNumber(String value) {
- return isInteger(value) || isDouble(value);
- }