5-8万年薪顶级嵌入式,京沪深就业地 浅谈并行编程中的任务分解模式
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  Java >  J2SE / 基础类

怎样将数字金额转换成中外大写金额(java实现)

楼主wuledile()2006-03-01 11:43:33 在 Java / J2SE / 基础类 提问

怎样将数字金额转换成中外大写金额(java实现)!  
  急!在线等,解决马上给分! 问题点数:100、回复次数:9Top

1 楼pingpingx(柠檬)回复于 2006-03-01 11:47:53 得分 0

我以前在做财务软件时写过一个。呆会给你发过去Top

2 楼geniusli(纠级天使)回复于 2006-03-01 14:03:02 得分 3

什么样的问题呢?是把1233转换成'壹贰参参'还是'壹千贰佰参拾参元整'Top

3 楼wuledile()回复于 2006-03-01 15:05:45 得分 0

不好意思我没有说清楚  
  101230.35转换为“十万壹千贰佰参拾参元叁角伍分”Top

4 楼lcl101(木木)回复于 2006-03-01 16:53:25 得分 1

自己写一个Top

5 楼wuledile()回复于 2006-03-01 17:03:52 得分 0

大家帮帮忙啊,很急啊!  
  在线等,测试通过马上给分!Top

6 楼pingpingx(柠檬)回复于 2006-03-01 17:04:13 得分 96

我自己做的找不到了,我在网上搜到一个,转贴下:  
  问题:         商业领域,开发票,支票等金钱相关项目通常要求转换成大写,诸如“壹拾圆陆角玖分”.编程过程中,一般的钱币都是double型.  
   
  当前看到的方法:之所以写这个方法,因为看到的方法设计的不是很好,通常的做法就是逐个字符处理,通过冗长的switch...case结构判断,来决定当前是否应该输出某某汉字,总体来说,完成这件任务是简单的,但是代码和设计质量却不令人满意.  
   
   
  设计方法如下:  
  需要注意的问题:  
          1.各个阿拉伯数字可以通过一个数组'壹','贰','叁'....表示.  
          2.对于大于10000和大于100000000的数字,可能出现'万','亿'字样  
          3.对于中间连续为0的数字,正确出现'零'的字样,但是有几种不同的情况需要处理  
          4.对于某个段的数字全零的情况,例如,整个万段都是0的情况-100000101,中间的0如何出现  
          5.角分的处理,如果不存在角分的话,应该出现'圆整'的字样  
          6.整数部分不存在的情况,即只有角分,应该没有'圆'的字样  
  设计框架:  
          1.把数字转化成字符串处理,使用Java的时候,把一个double类型转化成一个字符串类型很简单,  
          调用         String.valueOf(double_var)即可得到,但是有一个问题,当你的数字大于10个位的时候,  
          也就是达亿的时候,他会转换成科学计数法的字串,解决方法就是把他转化成整形long.  
   
          2.把数字分割成整数部分和小数部分分别处理,根据上面的方法,我们索性把double乘上100,  
          取后两位为小数部分,前面的为整数部分,得到  
          long   l   =   (long)(d*100);  
          String   strVal   =   String.valueOf(l);  
          String   head   =   strVal.substring(0,strVal.length()-2);                   //整数部分  
          String   end   =   strVal.substring(strVal.length()-2);                             //小数部分  
           
          3.我们应该把钱数分成段,每四个一段,实际上得到的是一个二维数组,如下:  
                          仟                 佰                 拾                   '   '  
          '   '             $4                 $3                 $2                   $1  
          万           $8                 $7               $6                     $5  
          亿           $12             $11           $10                 $9  
           
          其中$i表示这个数字的第i个位置的数字,我们并不实际设定二维数组,我们得到的是数字的位置,  
          要处理的该产生什么样的表示法,很简单这种处理方式往往就是:设pos表示数字位置,pos/4   在那一个段  
          万以下段,万段,亿段.pos%4表示某一个段的段内位置,仟,佰,拾,由于叠加的缘故,即会有千万,百万,千亿等  
          出现,因此这种设计是成立的.这里面隐含了一个问题就是,我们当前的处理的最大数字达千亿位,  
          更大的数字用这种结构是不妥的,因为可能会有万亿,这时候推荐的想法是把这些设计成单维的数组结构,  
          从而取得叠加的表示.  
          4.循环处理各个位的过程中,我们可以预想到,零的问题是最难解决的.  
          因为我们多个连续的零你只能出现一个表示,更有甚者,当某段全为0时,'零'还不能出现.  
          因此这些问题综合考虑得到以下代码.  
   
   
  代码:(JAVA描述)  
  public   static   String   changeToBig(double   value){  
          char[]   hunit={'拾','佰','仟'};                                                                                               //段内位置表示  
          char[]   vunit={'万','亿'};                                                                                                           //段名表示  
          char[]   digit={'零','壹','贰','叁','肆','伍','陆','柒','捌','玖'};     //数字表示  
          long   midVal   =   (long)(value*100);                                                                             //转化成整形  
          String   valStr=String.valueOf(midVal);                                                                 //转化成字符串  
          String   head=valStr.substring(0,valStr.length()-2);                               //取整数部分  
          String   rail=valStr.substring(valStr.length()-2);                                           //取小数部分  
   
          String   prefix="";                                                                                                                                   //整数部分转化的结果  
          String   suffix="";                                                                                                                                     //小数部分转化的结果  
          //处理小数点后面的数  
          if(rail.equals("00")){                                                                                                                         //如果小数部分为0  
              suffix="整";  
          }   else{  
              suffix=digit[rail.charAt(0)-'0']+"角"+digit[rail.charAt(1)-'0']+"分";                 //否则把角分转化出来  
          }  
          //处理小数点前面的数  
          char[]   chDig=head.toCharArray();                                                                                                                   //把整数部分转化成字符数组  
          char   zero='0';                                                                                                                                                                                     //标志'0'表示出现过0  
          byte   zeroSerNum   =   0;                                                                                                                                                         //连续出现0的次数  
          for(int   i=0;i<chDig.length;i++){                                                                                                                               //循环处理每个数字  
              int   idx=(chDig.length-i-1)%4;                                                                                                                                 //取段内位置  
              int   vidx=(chDig.length-i-1)/4;                                                                                                                                 //取段位置  
              if(chDig[i]=='0'){                                                                                                                                                                     //如果当前字符是0  
                  zeroSerNum++;                                                                                                                                                                   //连续0次数递增  
                  if(zero   ==   '0'){                                                                                                                                                                         //标志  
                      zero=digit[0];  
                  }   else   if(idx==0   &&   vidx   >0   &&zeroSerNum   <   4){  
                      prefix   +=   vunit[vidx-1];  
                      zero='0';  
                  }  
                  continue;  
              }  
              zeroSerNum   =   0;                                                                                                                                                                         //连续0次数清零  
              if(zero   !=   '0')   {                                                                                                                                                                                 //如果标志不为0,则加上,例如万,亿什么的  
                  prefix+=zero;  
                  zero='0';  
              }  
              prefix+=digit[chDig[i]-'0'];                                                                                                                                                 //转化该数字表示  
              if(idx   >   0)   prefix   +=   hunit[idx-1];                                      
              if(idx==0   &&   vidx>0){  
                  prefix+=vunit[vidx-1];                                                                                                                                                           //段结束位置应该加上段名如万,亿  
              }  
          }  
   
          if(prefix.length()   >   0)   prefix   +=   '圆';                                                                                                                           //如果整数部分存在,则有圆的字样  
          return   prefix+suffix;                                                                                                                                                                           //返回正确表示  
      }  
   
  Top

7 楼pingpingx(柠檬)回复于 2006-03-01 17:05:14 得分 0

测试能通过,我试过了!Top

8 楼wuledile()回复于 2006-03-01 17:27:49 得分 0

哈哈,测试通过了,问题OK了,谢谢!Top

9 楼Mikey2006(淘气小子)回复于 2006-03-01 18:02:29 得分 0

强!!学习支持!!不过代码还是太容重了!能不能将功能更加细分啊!!代码太多看的人烟花!!谢谢!1Top

相关问题

  • 有人能提供一个Java版的数字金额转换成大写金额的程序吗?
  • 小写金额转换
  • 大写金额转换
  • 金额大小写转换???
  • 大小写金额转换
  • 金额的大小写转换请教!!
  • 〉〉〉如何将一个数字金额转换为大写金额?〈〈〈
  • 求小写金额转换成大写金额的函数
  • 如何把金额转换成大写金额 急!!!
  • 求“数字金额转换汉字金额”原代码?

关键词

  • 转换
  • 数字
  • 代码
  • 测试
  • 金额
  • 角分
  • 字样
  • prefix+
  • 设计
  • 方法

得分解答快速导航

  • 帖主:wuledile
  • geniusli
  • lcl101
  • pingpingx

相关链接

  • CSDN Java频道
  • Java类图书
  • Java类源码下载

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
x 提问