All Downloads are FREE. Search and download functionalities are using the official Maven repository.

club.zhcs.utils.Numbers Maven / Gradle / Ivy

package club.zhcs.utils;

import java.math.BigDecimal;
import java.math.RoundingMode;
import java.text.DecimalFormat;
import java.text.NumberFormat;

import org.nutz.lang.Nums;

/**
 * 数字格式化工具类
 * 
 * @author LiuJunGuang
 */
public class Numbers extends Nums {
	/**
	 * 格式化数字
	 * 
	 * @param number    待格式化数据
	 * @param precision 小数位数
	 * @return 格式结果
	 */
	public static String format(double number, int precision) {
		if (number == 0) {
			StringBuilder bld = new StringBuilder();
			bld.append("0.");
			for (int i = 0; i < precision; i++) {
				bld.append("0");
			}
			return bld.toString();
		}
		number = keepPrecision(number, precision);
		StringBuilder bld = new StringBuilder();
		bld.append("###,###.");
		for (int i = 0; i < precision; i++) {
			bld.append("#");
		}
		NumberFormat formatter = new DecimalFormat(bld.toString());
		String target = formatter.format(number);
		int ps = 0;
		if (target.split("\\.").length > 1) {
			ps = target.split("\\.")[1].length();
		} else if (precision == 0) {
			return target.substring(0, target.length() - 1);
		} else {
			target += ".";
		}
		if (ps != precision) {
			for (int i = 0; i < precision - ps; i++) {
				target += "0";
			}
		}
		return target;
	}

	/**
	 * 格式化数字
	 * 
	 * @param number    待格式化数据
	 * @param precision 小数位数
	 * @return 格式化结果
	 */
	public static String format(float number, int precision) {
		if (number == 0) {
			StringBuilder temp = new StringBuilder("0.");
			for (int i = 0; i < precision; i++) {
				temp.append("0");
			}
			return temp.toString();
		}
		number = keepPrecision(number, precision);
		StringBuilder base = new StringBuilder("###,###.");
		for (int i = 0; i < precision; i++) {
			base.append("#");
		}
		NumberFormat formatter = new DecimalFormat(base.toString());
		String target = formatter.format(number);
		int ps = 0;
		if (target.split("\\.").length > 1) {
			ps = target.split("\\.")[1].length();
		} else if (precision == 0) {
			return target.substring(0, target.length() - 1);
		} else {
			target += ".";
		}
		StringBuilder sb = new StringBuilder(target);
		if (ps != precision) {
			for (int i = 0; i < precision - ps; i++) {
				sb.append(0);
			}
		}
		return sb.toString();
	}

	/**
	 * 格式化数字
	 * 
	 * @param number    待格式化数据
	 * @param precision 小数位数
	 * @return 格式化结果
	 */
	public static String format(Number number, int precision) {
		return format(number.toString(), precision);
	}

	/**
	 * 格式化数字
	 * 
	 * @param num       待格式化数据
	 * @param precision 小数位数
	 * @return 格式化结果
	 */
	public static String format(String num, int precision) {
		return format(Double.parseDouble(num), precision);

	}

	/**
	 * 对double类型的数值保留指定位数的小数。
* 该方法舍入模式:向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。
* 注意:如果精度要求比较精确请使用 keepPrecision(String number, int precision)方法 * * @param number 要保留小数的数字 * @param precision 小数位数 * @return double 如果数值较大,则使用科学计数法表示 */ public static double keepPrecision(double number, int precision) { BigDecimal bg = BigDecimal.valueOf(number); return bg.setScale(precision, RoundingMode.HALF_UP).doubleValue(); } /** * 对float类型的数值保留指定位数的小数。
* 该方法舍入模式:向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。
* 注意:如果精度要求比较精确请使用 keepPrecision(String number, int precision)方法 * * @param number 要保留小数的数字 * @param precision 小数位数 * @return float 如果数值较大,则使用科学计数法表示 */ public static float keepPrecision(float number, int precision) { BigDecimal bg = BigDecimal.valueOf(number); return bg.setScale(precision, RoundingMode.HALF_UP).floatValue(); } /** * 格式化为指定位小数的数字,返回未使用科学计数法表示的具有指定位数的字符串。
* 该方法舍入模式:向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。
* 如果给定的数字没有小数,则转换之后将以0填充;例如:int 123 1 → 123.0
* 注意:如果精度要求比较精确请使用 keepPrecision(String number, int precision)方法 * * @param number String类型的数字对象 * @param precision 小数精确度总位数,如2表示两位小数 * @return 返回数字格式化后的字符串表示形式(注意返回的字符串未使用科学计数法) */ public static String keepPrecision(Number number, int precision) { return keepPrecision(String.valueOf(number), precision); } /** * 格式化为指定位小数的数字,返回未使用科学计数法表示的具有指定位数的字符串。 * 该方法舍入模式:向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。 * *
	 * 	"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
	 * 
* * @param number String类型的数字对象 * @param precision 小数精确度总位数,如2表示两位小数 * @return 返回数字格式化后的字符串表示形式(注意返回的字符串未使用科学计数法) */ public static String keepPrecision(String number, int precision) { BigDecimal bg = new BigDecimal(number); return bg.setScale(precision, RoundingMode.HALF_UP).toPlainString(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy