import java.math.BigDecimal;
import java.math.RoundingMode;
public class MoneyUtils {
private static final String[] CN_UPPER_NUMBER = {"零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"};
private static final String[] CN_UPPER_MONEY_UNIT = {"分", "角", "元", "拾", "佰", "仟", "万", "拾",
"佰", "仟", "亿", "拾", "佰", "仟", "兆", "拾",
"佰", "仟"};
private static final String CN_FULL = "";
private static final String CN_NEGATIVE = "负";
private static final String CN_ZERO_FULL = "零元整";
private static final int MONEY_PRECISION = 2;
public static String number2CNMontray(String numberOfMoney) {
return number2CNMontray(new BigDecimal(numberOfMoney));
}
public static String number2CNMontray(BigDecimal numberOfMoney) {
StringBuffer sb = new StringBuffer();
int signum = numberOfMoney.signum();
if (signum == 0) {
return CN_ZERO_FULL;
}
long number = numberOfMoney.movePointRight(MONEY_PRECISION).setScale(0, 4).abs().longValue();
long scale = number % 100;
int numUnit = 0;
int numIndex = 0;
boolean getZero = false;
if (!(scale > 0)) {
numIndex = 2;
number = number / 100;
getZero = true;
}
if ((scale > 0) && (!(scale % 10 > 0))) {
numIndex = 1;
number = number / 10;
getZero = true;
}
int zeroSize = 0;
while (true) {
if (number <= 0) {
break;
}
numUnit = (int) (number % 10);
if (numUnit > 0) {
if ((numIndex == 9) && (zeroSize >= 3)) {
sb.insert(0, CN_UPPER_MONEY_UNIT[6]);
}
if ((numIndex == 13) && (zeroSize >= 3)) {
sb.insert(0, CN_UPPER_MONEY_UNIT[10]);
}
sb.insert(0, CN_UPPER_MONEY_UNIT[numIndex]);
sb.insert(0, CN_UPPER_NUMBER[numUnit]);
getZero = false;
zeroSize = 0;
} else {
++zeroSize;
if (!(getZero)) {
sb.insert(0, CN_UPPER_NUMBER[numUnit]);
}
if (numIndex == 2) {
if (number > 0) {
sb.insert(0, CN_UPPER_MONEY_UNIT[numIndex]);
}
} else if (((numIndex - 2) % 4 == 0) && (number % 1000 > 0)) {
sb.insert(0, CN_UPPER_MONEY_UNIT[numIndex]);
}
getZero = true;
}
number = number / 10;
++numIndex;
}
if (signum == -1) {
sb.insert(0, CN_NEGATIVE);
}
if (!(scale > 0)) {
sb.append(CN_FULL);
}
return sb.toString();
}
public static String accountantMoney(BigDecimal money) {
return accountantMoney(money, 2, 1);
}
public static String getFormatMoney(BigDecimal money, int scale, double divisor) {
return formatMoney(money, scale, divisor) + getCellFormat(divisor);
}
public static String getAccountantMoney(BigDecimal money, int scale, double divisor) {
return accountantMoney(money, scale, divisor) + getCellFormat(divisor);
}
private static String accountantMoney(BigDecimal money, int scale, double divisor) {
String disposeMoneyStr = formatMoney(money, scale, divisor);
int dotPosition = disposeMoneyStr.indexOf(".");
String exceptDotMoney = null;
String dotMoney = null;
if (dotPosition > 0) {
exceptDotMoney = disposeMoneyStr.substring(0, dotPosition);
dotMoney = disposeMoneyStr.substring(dotPosition);
} else {
exceptDotMoney = disposeMoneyStr;
}
int negativePosition = exceptDotMoney.indexOf("-");
if (negativePosition == 0) {
exceptDotMoney = exceptDotMoney.substring(1);
}
StringBuffer reverseExceptDotMoney = new StringBuffer(exceptDotMoney);
reverseExceptDotMoney.reverse();
char[] moneyChar = reverseExceptDotMoney.toString().toCharArray();
StringBuffer returnMeony = new StringBuffer();
for (int i = 0; i < moneyChar.length; i++) {
if (i != 0 && i % 3 == 0) {
returnMeony.append(",");
}
returnMeony.append(moneyChar[i]);
}
returnMeony.reverse();
if (dotPosition > 0) {
returnMeony.append(dotMoney);
}
if (negativePosition == 0) {
return "-" + returnMeony.toString();
} else {
return returnMeony.toString();
}
}
private static String formatMoney(BigDecimal money, int scale, double divisor) {
if (divisor == 0) {
return "0.00";
}
if (scale < 0) {
return "0.00";
}
BigDecimal divisorBD = new BigDecimal(divisor);
return money.divide(divisorBD, scale, RoundingMode.HALF_UP).toString();
}
private static String getCellFormat(double divisor) {
String str = String.valueOf(divisor);
int len = str.substring(0, str.indexOf(".")).length();
String cell = "";
switch (len) {
case 1:
cell = "元";
break;
case 2:
cell = "十元";
break;
case 3:
cell = "百元";
break;
case 4:
cell = "千元";
break;
case 5:
cell = "万元";
break;
case 6:
cell = "十万元";
break;
case 7:
cell = "百万元";
break;
case 8:
cell = "千万元";
break;
case 9:
cell = "亿元";
break;
case 10:
cell = "十亿元";
break;
}
return cell;
}
}