近来接触到人民币大写与阿拉伯数字相互转换的问题,贴上来保存
package com.fancy.algorithm;
/**
*
* @author fancy205
* 2010-05-04
*/
public class MoneyUtil {
/**
* @param args
*/
public static void main(String[] args) {
System.out.println(numToCN(10000000000L));
// System.out.println(cnToNum("玖拾亿伍仟万零伍元"));
// System.out.println(Integer.MAX_VALUE);
}
/**
* 阿拉伯数字转为人民币大写
* @param num 123456789
*/
protected static String numToCN(long momey){
String[] unitArray = {"分", "角", "元", "拾", "佰", "仟", "万", "拾", "佰", "仟", "亿", "拾", "佰", "仟"};
String[] numArray = {"零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"};
if (momey == 0) {
return "零元整";
}
String str = Long.toString(momey*100);
char[] arr = str.toCharArray();
int len = arr.length;
int zero = 0;
StringBuffer targetNum = new StringBuffer();
for(int i=0;i<arr.length;i++){
String s = arr[i]+"";
int num = Integer.parseInt(s);
int unitNum = len-i-1;
if(num==0){
zero++;
if (unitNum == 2 || unitNum == 6 || unitNum == 10)
{
if (unitNum == 2 || zero < 4)
targetNum.append(unitArray[unitNum]);
zero = 0;
}
}else{
if (zero > 0)
{
targetNum.append(numArray[0]);
zero = 0;
}
targetNum.append(numArray[num]);
targetNum.append(unitArray[unitNum]);
}
}
if(zero>0){
targetNum.append("整");
}
return targetNum.toString();
}
/**
* 人民币大写转换成阿拉伯数字
* @param str 壹亿五千零二十万零五元
* @return
*/
protected static long cnToNum(String str){
String numStr = "零壹贰叁肆伍陆柒捌玖";
String unitStr = "分角圆拾佰仟万拾佰仟亿拾佰仟";
char[] arr = str.toCharArray();
long sum = 0l;
int len = arr.length;
int num = 0;
int unit = 0;
for(int i=0;i<len;i++){
String key = arr[i]+"";
int index = numStr.indexOf(key);
if(index!=-1) {
num = index;
}else {
unit = unitStr.indexOf(key);
if(num!=0){
if(unit==6 || unit==10 || unit==14){
sum *= Math.pow(10,unit-2);
}else {
if(unit<=2){
sum +=num;
num = 0;
}else{
sum += num * Math.pow(10,unit-2);
}
}
}
}
}
return sum;
}
}
分享到:
相关推荐
函数功能与参数:将阿拉伯数字转为人民币金额大写。仅需要一个参数,即单元格引用。 函数名称:批注 函数功能与参数:提取批注中的文字。只有一个参数,即单元格引用。 函数名称:合并 函数功能与参数:将区域...
函数功能与参数:将阿拉伯数字转为人民币金额大写。仅需要一个参数,即单元格引用。 函数名称:批注 函数功能与参数:提取批注中的文字。只有一个参数,即单元格引用。 函数名称:合并 函数功能与参数:将区域...
该函数实现了人民币金额在大写和小写之间的相互转换,满足了财务文档中对于金额书写的规范要求。 #### 10. 查汉字区位码 此函数用于查找汉字的区位码,对于汉字编码研究或特定汉字的编码查询有重要意义。 #### 11...
5. **人民币大小写金额转换**:在金融应用中,需要将阿拉伯数字的金额转换为汉字大写的格式,以符合财务规范。这通常涉及到一系列的条件判断和字符串拼接。例如,编写一个函数,根据输入的数字,将“123456.78”转换...
- **说明**:此函数可以实现人民币金额的大写和小写相互转换。 - **应用场景**:适用于财务报表和正式文档编写。 23. **函数作用:获取区域颜色值** - **说明**:此函数可以获取Excel单元格的背景颜色值。 - **...