保留几位小数或者4舍5入的方法

java.text.DecimalFormat   myformat=new   java.text.DecimalFormat("#0.00");   
  //然后就用:   
  myformat.format(a);   
  //如:   
  double a;   
  a= 3.1415926;    
    
  System.out.println(myformat.format(a));  

//或者
//4舍5入法 
double a=3.1415926 ;   
BigDecimal a=new  BigDecimal(f);   
double af  =  b.setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue();

Math.round();用于4舍5入.
ROUND_HALF_UP: 遇到.5的情况时往上近似,例: 1.5 ->;2
ROUND_HALF_DOWN : 遇到.5的情况时往下近似,例: 1.5 ->;1

BigDecimal a = new BigDecimal(1.5);
                System.out.println("down="+a.setScale(0,BigDecimal.ROUND_HALF_DOWN)+"\tup="+a.setScale(0,BigDecimal.ROUND_HALF_UP));
结果:down=1  up=2 

Math.floor()、Math.ceil()、BigDecimal都是Java中的取整函数,但返回值却不一样

Math.floor()
通过该函数计算后的返回值是舍去小数点后的数值
如:Math.floor(3.2)返回3
Math.floor(3.9)返回3
Math.floor(3.0)返回3

Math.ceil()
ceil函数只要小数点非0,将返回整数部分+1
如:Math.ceil(3.2)返回4
Math.ceil(3.9)返回4
Math.ceil(3.0)返回3

BigDecimal四舍五入
传统的四舍五入,在Math类中并没有直接提供,必须使用Java.math.BigDecimal类来实现
new BigDecimal("2.0").setScale(0, BigDecimal.ROUND_HALF_UP)返回2
new BigDecimal("2.4").setScale(0, BigDecimal.ROUND_HALF_UP)返回2

new BigDecimal("2.5").setScale(0, BigDecimal.ROUND_HALF_UP)返回3


package com.ics8000.util;

import java.math.BigDecimal;

public class MathExtend

{

 // 默认除法运算精度

 public static final int DEFAULT_DIV_SCALE = 2;

 /**
  *
  * 提供精确的加法运算。
  *
  * @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 String add(String v1, String v2)

 {

  BigDecimal b1 = new BigDecimal(v1);

  BigDecimal b2 = new BigDecimal(v2);

  return b1.add(b2).toString();

 }

 /**
  *
  * 提供精确的减法运算。
  *
  * @param v1
  *
  * @param v2
  *
  * @return 两个参数的差
  *
  */

 public static double subtract(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 String subtract(String v1, String v2)

 {

  BigDecimal b1 = new BigDecimal(v1);

  BigDecimal b2 = new BigDecimal(v2);

  return b1.subtract(b2).toString();

 }

 /**
  *
  * 提供精确的乘法运算。
  *
  * @param v1
  *
  * @param v2
  *
  * @return 两个参数的积
  *
  */

 public static double multiply(double v1, double v2)

 {

  BigDecimal b1 = new BigDecimal(Double.toString(v1));

  BigDecimal b2 = new BigDecimal(Double.toString(v2));

  return b1.multiply(b2).doubleValue();

 }

 /**
  *
  * 提供精确的乘法运算
  *
  * @param v1
  *
  * @param v2
  *
  * @return 两个参数的数学积,以字符串格式返回
  *
  */

 public static String multiply(String v1, String v2)

 {

  BigDecimal b1 = new BigDecimal(v1);

  BigDecimal b2 = new BigDecimal(v2);

  return b1.multiply(b2).toString();

 }

 /**
  *
  * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到
  *
  * 小数点以后10位,以后的数字四舍五入,舍入模式采用ROUND_HALF_EVEN
  *
  * @param v1
  *
  * @param v2
  *
  * @return 两个参数的商
  *
  */

 public static double divide(double v1, double v2)

 {

  return divide(v1, v2, DEFAULT_DIV_SCALE);

 }

 /**
  *
  * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
  *
  * 定精度,以后的数字四舍五入。舍入模式采用ROUND_HALF_EVEN
  *
  * @param v1
  *
  * @param v2
  *
  * @param scale
  *            表示需要精确到小数点以后几位。
  *
  * @return 两个参数的商
  *
  */

 public static double divide(double v1, double v2, int scale)

 {

  return divide(v1, v2, scale, BigDecimal.ROUND_HALF_EVEN);

 }

 /**
  *
  * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
  *
  * 定精度,以后的数字四舍五入。舍入模式采用用户指定舍入模式
  *
  * @param v1
  *
  * @param v2
  *
  * @param scale
  *            表示需要精确到小数点以后几位
  *
  * @param round_mode
  *            表示用户指定的舍入模式
  *
  * @return 两个参数的商
  *
  */

 public static double divide(double v1, double v2, int scale, int round_mode) {

  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, round_mode).doubleValue();

 }

 /**
  *
  * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到
  *
  * 小数点以后10位,以后的数字四舍五入,舍入模式采用ROUND_HALF_EVEN
  *
  * @param v1
  *
  * @param v2
  *
  * @return 两个参数的商,以字符串格式返回
  *
  */

 public static String divide(String v1, String v2)

 {

  return divide(v1, v2, DEFAULT_DIV_SCALE);

 }

 /**
  *
  * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
  *
  * 定精度,以后的数字四舍五入。舍入模式采用ROUND_HALF_EVEN
  *
  * @param v1
  *
  * @param v2
  *
  * @param scale
  *            表示需要精确到小数点以后几位
  *
  * @return 两个参数的商,以字符串格式返回
  *
  */

 public static String divide(String v1, String v2, int scale)

 {

  return divide(v1, v2, DEFAULT_DIV_SCALE, BigDecimal.ROUND_HALF_EVEN);

 }

 /**
  *
  * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
  *
  * 定精度,以后的数字四舍五入。舍入模式采用用户指定舍入模式
  *
  * @param v1
  *
  * @param v2
  *
  * @param scale
  *            表示需要精确到小数点以后几位
  *
  * @param round_mode
  *            表示用户指定的舍入模式
  *
  * @return 两个参数的商,以字符串格式返回
  *
  */

 public static String divide(String v1, String v2, int scale, int round_mode)

 {

  if (scale < 0)

  {

   throw new IllegalArgumentException(
     "The scale must be a positive integer or zero");

  }

  BigDecimal b1 = new BigDecimal(v1);

  BigDecimal b2 = new BigDecimal(v2);

  return b1.divide(b2, scale, round_mode).toString();

 }

 /**
  *
  * 提供精确的小数位四舍五入处理,舍入模式采用ROUND_HALF_EVEN
  *
  * @param v
  *            需要四舍五入的数字
  *
  * @param scale
  *            小数点后保留几位
  *
  * @return 四舍五入后的结果
  *
  */

 public static double round(double v, int scale)

 {

  return round(v, scale, BigDecimal.ROUND_HALF_EVEN);

 }

 /**
  *
  * 提供精确的小数位四舍五入处理
  *
  * @param v
  *            需要四舍五入的数字
  *
  * @param scale
  *            小数点后保留几位
  *
  * @param round_mode
  *            指定的舍入模式
  *
  * @return 四舍五入后的结果
  *
  */

 public static double round(double v, int scale, int round_mode)

 {

  if (scale < 0)

  {

   throw new IllegalArgumentException(
     "The scale must be a positive integer or zero");

  }

  BigDecimal b = new BigDecimal(Double.toString(v));

  return b.setScale(scale, round_mode).doubleValue();

 }

 /**
  *
  * 提供精确的小数位四舍五入处理,舍入模式采用ROUND_HALF_EVEN
  *
  * @param v
  *            需要四舍五入的数字
  *
  * @param scale
  *            小数点后保留几位
  *
  * @return 四舍五入后的结果,以字符串格式返回
  *
  */

 public static String round(String v, int scale)

 {

  return round(v, scale, BigDecimal.ROUND_HALF_EVEN);

 }

 /**
  *
  * 提供精确的小数位四舍五入处理
  *
  * @param v
  *            需要四舍五入的数字
  *
  * @param scale
  *            小数点后保留几位
  *
  * @param round_mode
  *            指定的舍入模式
  *
  * @return 四舍五入后的结果,以字符串格式返回
  *
  */

 public static String round(String v, int scale, int round_mode)

 {

  if (scale < 0)

  {

   throw new IllegalArgumentException(
     "The scale must be a positive integer or zero");

  }

  BigDecimal b = new BigDecimal(v);

  return b.setScale(scale, round_mode).toString();

 }
 
 /**
  * 要求舍入后返回BigDecimal类型
  *
  * @param dou
  *            待舍入的数字
  * @param scale
  *            返回的BigDecimal对象的标度(scale)
  * @param roundmode
  *            舍入模式
  * @return
  */
 public static BigDecimal getRound(double dou, int scale, int roundmode) {
  // 创建一个新的BigDecimal对象paramNumber,该对象的值和dou大小一样。
  BigDecimal paramNumber = new BigDecimal(dou);
  // 然后调用paramNumber的setScale方法,该方法返回一个 BigDecimal对象temp,
  // 返回值的标度为第一个参数指定的值,标度为大小表示小数部分的位数
  // 第二个参数指定了paramNumber对象到temp对象的舍入模式,如四舍五入等。
  return paramNumber.setScale(scale, roundmode);
  // 实际可以一条语句实现:return new BigDecimal(dou).setScale(0, roundmode);
 }

}






  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中,有多种方法可以实现保留小数位数的需求。其中一种常见的方法是使用字符串格式化。你可以使用百分号(%)来格式化输出,并指定小数位数。例如,你可以使用以下代码来保留两位小数: a = 12.345 print("%.2f" % a) 这段代码中,%代表格式化输出,.2表示保留两位小数,f表示数据类型是浮点型。运行这段代码后,输出将会是12.35,保留了两位小数。 另外一种方法是使用内置函数round来实现保留小数位数的效果。你可以使用round函数将浮点数四到指定的小数位数。例如,你可以使用以下代码来保留两位小数: a = 12.34567889 print(round(a, 2)) 这段代码中,round函数的第一个参数是要进行四的数值,第二个参数是要保留小数位数。运行这段代码后,输出也将会是12.35,同样保留了两位小数。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [python怎么保留两位小数?几种方法总结!](https://blog.csdn.net/m0_69824302/article/details/132320677)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [python保留两位小数或者多位小数方法](https://blog.csdn.net/weixin_44076384/article/details/86680363)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值