保留两位小数{
方法一:{
double c=3.154215;
Java.text.DecimalFormat myformat=new java.text.DecimalFormat("0.00");
String str = myformat.format(c);
}
方式二:{
java.text.DecimalFormat df =new java.text.DecimalFormat("#.00");
df.format(你要格式化的数字);
例:new java.text.DecimalFormat("#.00").format(3.1415926)
#.00 表示两位小数 #.0000四位小数 以此类推...
}
方式三:{
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();
}
- public class PreciseCompute {
-
- private static final int DEF_DIV_SCALE = 10;
-
-
-
-
-
-
-
-
- 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();
- }
-
-
-
-
-
-
-
-
- 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();
- }
-
-
-
-
-
-
-
- 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();
- }
-
-
-
-
-
-
-
-
-
- public static double div(double v1, double v2) {
- return div(v1, v2, DEF_DIV_SCALE);
- }
-
-
-
-
-
-
-
-
-
- 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();
- }
-
-
-
-
-
-
-
- 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:
- 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);
- }
详细参看JavaSE 帮助文档.