`
fancy205
  • 浏览: 14407 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

人民币大写与阿拉伯数字相互转换工具类

 
阅读更多

      近来接触到人民币大写与阿拉伯数字相互转换的问题,贴上来保存

     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;
	}
}
 
2
2
分享到:
评论
1 楼 fkpj_bit 2012-05-23  
代码有一处有问题:
if(unit==6 || unit==10 || unit==14){  
                        sum *=  Math.pow(10,unit-2);  
                    }

如果num对应的单位是万,亿,因为sum没有加上num,会把这个num给吞掉,同时,如果单纯按照unitStr方式查找中文对应的单位时,就此处代码应改为
if (unit == 6 || unit == 10) {
						//碰到万,或者亿
						sum += num;
						sum *= Math.pow(10, 4);
					}

相关推荐

    Excel百宝箱9.0无限制破解版.rar

    函数功能与参数:将阿拉伯数字转为人民币金额大写。仅需要一个参数,即单元格引用。 函数名称:批注 函数功能与参数:提取批注中的文字。只有一个参数,即单元格引用。 函数名称:合并 函数功能与参数:将区域...

    Exce百宝箱——2012版本.rar

    函数功能与参数:将阿拉伯数字转为人民币金额大写。仅需要一个参数,即单元格引用。 函数名称:批注 函数功能与参数:提取批注中的文字。只有一个参数,即单元格引用。 函数名称:合并 函数功能与参数:将区域...

    excel中161个VBA_自定义函数(超级实用)

    该函数实现了人民币金额在大写和小写之间的相互转换,满足了财务文档中对于金额书写的规范要求。 #### 10. 查汉字区位码 此函数用于查找汉字的区位码,对于汉字编码研究或特定汉字的编码查询有重要意义。 #### 11...

    c#常用代码段

    5. **人民币大小写金额转换**:在金融应用中,需要将阿拉伯数字的金额转换为汉字大写的格式,以符合财务规范。这通常涉及到一系列的条件判断和字符串拼接。例如,编写一个函数,根据输入的数字,将“123456.78”转换...

    VBA_Excel自定义函数大全

    - **说明**:此函数可以实现人民币金额的大写和小写相互转换。 - **应用场景**:适用于财务报表和正式文档编写。 23. **函数作用:获取区域颜色值** - **说明**:此函数可以获取Excel单元格的背景颜色值。 - **...

Global site tag (gtag.js) - Google Analytics