数据库里边存的钱单位是分,后来要转换成保留小数点之后2位的double类型的单位是元的钱,以下是公司的工具类
package com.wanshun.common.utils;
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.text.DecimalFormat;
public class CurrencyUtil {
/**
* 保留两位
* @param d
* @return
*/
public static double formatDouble2(double d) {
return new BigDecimal(d).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
}
/**
* 保留一位
* @param d
* @return
*/
public static double formatDouble1(double d) {
return new BigDecimal(d).setScale(1, BigDecimal.ROUND_HALF_UP).doubleValue();
}
/**
* 元 转 分 -- 保证精度准确
* @param price
* @return
*/
public static int yuanToFen(double price){
return (int) Double.parseDouble(BigDecimal.valueOf(price).multiply(new BigDecimal(100)).toString());
}
/**
* 元转分,确保price保留两位有效数字
* @return
*/
public static int changeY2F(double price) {
DecimalFormat df = new DecimalFormat("#.00");
price = Double.valueOf(df.format(price));
int money = (int)(price * 100);
return money;
}
/**
* 分转元,转换为bigDecimal在toString
* @return
*/
public static double changeF2Y(int price) {
return BigDecimal.valueOf(Double.valueOf(price * 1.0)).divide(new BigDecimal(100)).doubleValue();
}
public static double changeFL2YDouble(long price) {
return BigDecimal.valueOf(Double.valueOf(price * 1.0)).divide(new BigDecimal(100)).doubleValue();
}
/**
* 分(long)转元(double),转换为bigDecimal在toString
* @return
*/
public static String changeFL2Y(double price, int scale) {
DecimalFormat df = new DecimalFormat("0.00");
return df.format(BigDecimal.valueOf(Double.valueOf(price * 1.0)).divide(new BigDecimal(100)).doubleValue());
}
public static double changeF2Y(double price) {
return BigDecimal.valueOf(Double.valueOf(price * 1.0)).divide(new BigDecimal(100)).doubleValue();
}
public static BigDecimal changeF2Y2(int price) {
BigDecimal fen = new BigDecimal(price);
return fen.divide(new BigDecimal(100), 2, RoundingMode.HALF_UP);
}
/**
* @Description 分转元
* @param price
* @return java.lang.String
* @Date 2020-04-16 14:27
*/
public static String translateF2Y (Integer price) {
if(price != null){
DecimalFormat df = new DecimalFormat("0.00");
return df.format(BigDecimal.valueOf(Double.valueOf(price * 1.0)).divide(new BigDecimal(100)).doubleValue());
}else {
return "0.00";
}
}
}