1. 程式人生 > >數字格式化工具類 持續更新>>>

數字格式化工具類 持續更新>>>

/**
 * 數字格式化工具類
 */
public class NumberUtils {
    /**
	 * 格式化為指定位小數的數字,返回未使用科學計數法表示的具有指定位數的字串。
	 * 該方法舍入模式:向“最接近的”數字舍入,如果與兩個相鄰數字的距離相等,則為向上舍入的舍入模式。
	 * <pre>
	 * 	"3.1415926", 1			--> 3.1
	 * 	"3.1415926", 3			--> 3.142
	 * 	"3.1415926", 4			--> 3.1416
	 * 	"3.1415926", 6			--> 3.141593
	 * 	"1234567891234567.1415926", 3	--> 1234567891234567.142
	 * </pre>
	 * @param //String型別的數字物件
	 * @param precision  小數精確度總位數,如2表示兩位小數
	 * @return 返回數字格式化後的字串表示形式(注意返回的字串未使用科學計數法)
	 */
	public static String keepPrecision(String number, int precision) {
		BigDecimal bg = new BigDecimal(number);
		return bg.setScale(precision, BigDecimal.ROUND_HALF_UP).toPlainString();
	}
 
	/**
	 * 格式化為指定位小數的數字,返回未使用科學計數法表示的具有指定位數的字串。<br>
	 * 該方法舍入模式:向“最接近的”數字舍入,如果與兩個相鄰數字的距離相等,則為向上舍入的舍入模式。<br>
	 * 如果給定的數字沒有小數,則轉換之後將以0填充;例如:int 123  1 --> 123.0<br>
	 * <b>注意:</b>如果精度要求比較精確請使用 keepPrecision(String number, int precision)方法
	 * @param //String型別的數字物件
	 * @param precision  小數精確度總位數,如2表示兩位小數
	 * @return 返回數字格式化後的字串表示形式(注意返回的字串未使用科學計數法)
	 */
	public static String keepPrecision(Number number, int precision) {
		return keepPrecision(String.valueOf(number), precision);
	}
 
	/**
	 * 對double型別的數值保留指定位數的小數。<br>
	 * 該方法舍入模式:向“最接近的”數字舍入,如果與兩個相鄰數字的距離相等,則為向上舍入的舍入模式。<br>
	 * <b>注意:</b>如果精度要求比較精確請使用 keepPrecision(String number, int precision)方法
	 * @param number  要保留小數的數字
	 * @param precision 小數位數
	 * @return double 如果數值較大,則使用科學計數法表示
	 */
	public static double keepPrecision(double number, int precision) {
		BigDecimal bg = new BigDecimal(number);
		return bg.setScale(precision, BigDecimal.ROUND_HALF_UP).doubleValue();
	}
 
	/**
	 * 對float型別的數值保留指定位數的小數。<br>
	 * 該方法舍入模式:向“最接近的”數字舍入,如果與兩個相鄰數字的距離相等,則為向上舍入的舍入模式。<br>
	 * <b>注意:</b>如果精度要求比較精確請使用 keepPrecision(String number, int precision)方法
	 * @param number  要保留小數的數字
	 * @param precision 小數位數
	 * @return float 如果數值較大,則使用科學計數法表示
	 */
	public static float keepPrecision(float number, int precision) {
		BigDecimal bg = new BigDecimal(number);
		return bg.setScale(precision, BigDecimal.ROUND_HALF_UP).floatValue();
	}
	
	/**
	 * 獲取 ±number 的隨機數。<br>
	 * @param number  要保留小數的數字
	 * @return float 如果數值較大,則使用科學計數法表示
	 */
	private static float getRandomNum(int number) {
		Random random = new Random();
		//return num /2 + random.nextFloat() * num * -1;
		int randomNum = (random.nextInt(number)) * (random.nextInt(2) == 0 ? -1 : 1);
		String rd = randomNum + "." + random.nextInt(10);
		return Float.parseFloat(rd);
	}
	
	/**
	 * 去掉小數點後多餘的0。<br>
	 * 例如: 1.0 則返回 1。<br>
	 * @param number  要處理的數字
	 * @return double 
	 */
	public static double rvZeroAndDot(double number){
		String s = String.valueOf(number);
		if (s.isEmpty()) {
			return 0;
		}
		if(s.indexOf(".") > 0){
			s = s.replaceAll("0+?$", "");//去掉多餘的0
			s = s.replaceAll("[.]$", "");//如最後一位是.則去掉
		}
		return Double.parseDouble(s);
	}
 
}