博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java常用Money转换方法实现
阅读量:3778 次
发布时间:2019-05-22

本文共 2551 字,大约阅读时间需要 8 分钟。

public class MoneyUtils {
private static final String UNIT = "万千佰拾亿千佰拾万千佰拾元角分"; private static final String DIGIT = "零壹贰叁肆伍陆柒捌玖"; private static final double MAX_VALUE = 9999999999999.99D; /** * 将double类型的元转换成中文格式 */ public static String change(double v) {
if (v < 0 || v > MAX_VALUE) {
return "参数非法!"; } long l = Math.round(v * 100); if (l == 0) {
return "零元整"; } String strValue = l + ""; // i用来控制数 int i = 0; // j用来控制单位 int j = UNIT.length() - strValue.length(); String rs = ""; boolean isZero = false; for (; i < strValue.length(); i++, j++) {
char ch = strValue.charAt(i); if (ch == '0') {
isZero = true; if (UNIT.charAt(j) == '亿' || UNIT.charAt(j) == '万' || UNIT.charAt(j) == '元') {
rs = rs + UNIT.charAt(j); isZero = false; } } else {
if (isZero) {
rs = rs + "零"; isZero = false; } rs = rs + DIGIT.charAt(ch - '0') + UNIT.charAt(j); } } if (!rs.endsWith("分")) {
rs = rs + "整"; } rs = rs.replaceAll("亿万", "亿"); return rs; } /** * 将金额分转换成12,131.23格式的元 * 1000131 -> 10,001.31 * 100.31 -> 100.31 * 12 -> 0.12 * 100 -> 1 * 110 -> 1.1 * 10 -> 0.1 * 1 -> 0.01 * 0 -> 0 * @param amountFen 要转换的金额 单位为分 * @param grouping 是否以 10,001.31形式展示,否 则为10001.31 * @param tailTrim 是否去除小数点后的0 * @return String */ public static String fromFenToYuan(Long amountFen,boolean grouping,boolean tailTrim){
String pattern = (amountFen == 0L) ? "0.00" : ",##0.00"; BigDecimal amountYuan = Money.toYuan(amountFen); DecimalFormat decimalFormat = new DecimalFormat(pattern); String formatString = decimalFormat.format(amountYuan); if (!grouping) {
formatString = formatString.replaceAll(",",""); } if (!tailTrim) {
return formatString; } if (".00".equals(formatString.substring(formatString.length() - 3))) {
return formatString.substring(0,formatString.length() - 3); } if ("0".equals(formatString.substring(formatString.length() - 1))) {
return formatString.substring(0,formatString.length() - 1); } return formatString; }}

转载地址:http://mbpvn.baihongyu.com/

你可能感兴趣的文章
$listeners与.native的使用
查看>>
熟悉Linux 下静态库.a 与.so 库文件的生成与使用——实例
查看>>
算法训练 1的个数(输入正整数n,判断从1到n之中,数字1一共要出现几次。例如1123这个数,则出现了两次1。例如15,那么从1到15之中,一共出现了8个1。)
查看>>
算法训练 素因子去重(给定一个正整数n,求一个正整数p,满足p仅包含n的所有素因子,且每个素因子的次数不大于1)
查看>>
算法训练 二进制数数( 给定L,R。统计[L,R]区间内的所有数在二进制下包含的“1”的个数之和。   如5的二进制为101,包含2个“1”。)
查看>>
第十届MathorCup高校数学建模D题解题思路
查看>>
2020年高教社杯全国大学生数学建模竞赛赛题 C题分析与思路!(持续更新)
查看>>
2020年高教社杯全国大学生数学建模竞赛赛题 B题分析与思路!(持续更新)
查看>>
蓝桥杯真题 18省4-测试次数 x星球的居民脾气不太好,但好在他们生气的时候唯一的异常举动是:摔手机。 各大厂商也就纷纷推出各种耐摔型手机。x星球的质监局规定了手机必须经过耐摔测试,并且评定出一个耐
查看>>
蓝桥杯真题 19省3-数列求值 给定数列 1, 1, 1, 3, 5, 9, 17, …,从第 4 项开始,每项都是前 3 项的和。求第 20190324 项的最后 4 位数字。
查看>>
大小写字母转换函数tolower();的用法
查看>>
蓝桥杯 15校4-7对数字 今有7对数字:两个1,两个2,两个3,...两个7,把它们排成一行。 要求,两个1间有1个其它数字,两个2间有2个其它数字,以此类推,两个7之间有7个其它数字。如下就是
查看>>
蓝桥杯真题 17省10-k倍区间 给定一个长度为N的数列,A1, A2, ... AN,如果其中一段连续的子序列Ai, Ai+1, ... Aj(i <= j)之和是K的倍数,我们就称这个区间[i
查看>>
TCP协议的流量控制
查看>>
TCP连接的三次握手过程,为什么不是两次或四次?
查看>>
小白都能看懂的DNS解析过程
查看>>
HTTP和HTTPS的区别?描述HTTPS的工作过程
查看>>
简述一下HTTP的状态码
查看>>
20210227vulhub靶场之环境配置---无法获得靶机IP的疑难解决方式(可以解决VBox和VMware不兼容问题)
查看>>
20210226web渗透学习之SSRF总结
查看>>