『壹』 将数字货币金额转换为大写格式
【实例描述】
在处理财务账款时,一般需要使用大写金额。如果在银行进行储蓄或转账,也需要将数字金
额写成大写格式。也就是说,如果要转账123456元,则
需要写成“壹拾贰万叁仟肆佰伍拾陆元整”。对于这种情
况,如果手动填写不仅麻烦,而且容易出错,所以我们
可以设计一个程序来自动完成数字格式的转换。本实例
实现了小写金额到大写金额的转换,实例的运行效果如
图4.2所示。
图4.2将数字货币金额转换为大写格式
【实现过程】
(1)在Eclipse中新建项目MoneyConvert,并在其中创建一个MoneyConvert.java文件。
在该类的主方法中创建标准输入流的扫描器对象,接收用户输入的数字金额。然后在通过
convert()方法把这个金额转换成大写金额的字符串格式,并输出到控制台。核心代码如下所示:
publicstaticvoidmain(String[]args){
Scannerscan=newScanner(System.in);//创建扫描器
System.out.println("请输入一个金额");
//获取金额转换后的字符串
Stringconvert=convert(scan.nextDouble());
System.out.println(convert);//输出转换结果
}
(2)编写金额转换方法convert(),该方法在主方法中被调用,用于金额数字向大写格式的
转换。在该方法中创建DecimalFormat类的实例对象,通过这个格式器对象把金额数字格式化,
只保留三位小数。然后分别调用getInteger()与getDecimal()方法转换整数与小数部分,并返回
转换后的结果。关键代码如下:
publicstaticStringconvert(doubled){
//实例化DecimalFormat对象
DecimalFormatdf=newDecimalFormat("#0.###");
//格式化double数字
StringstrNum=df.format(d);
//判断是否包含小数点
if(strNum.indexOf(".")!=-1){
Stringnum=strNum.substring(0,strNum.indexOf("."));
//整数部分大于12不能转换
if(num.length()>12){
System.out.println("数字太大,不能完成转换!");
return"";
}
}
Stringpoint="";//小数点
if(strNum.indexOf(".")!=-1){
point="元";
}else{
point="元整";
}
//转换结果
Stringresult=getInteger(strNum)+point+getDecimal(strNum);
if(result.startsWith("元")){//判断是字符串是否已"元"结尾
result=result.substring(1,result.length());//截取字符串
}
returnresult;//返回新的字符串
}
(3)编写getInteger()方法,用于转换数字整数部分的大写格式。在该方法中判断数字是否
包含小数点,然后把数字转换为字符串并反转字符顺序,为每个数字添加对应的大写单位。关
键代码如下:
publicstaticStringgetInteger(Stringnum){
if(num.indexOf(".")!=-1){//判断是否包含小数点
um=num.substring(0,num.indexOf("."));
}
um=newStringBuffer(num).reverse().toString();//反转字符串
StringBuffertemp=newStringBuffer();//创建一个StringBuffer
对象
for(inti=0;i<num.length();i++){//加入单位
temp.append(STR_UNIT[i]);
temp.append(STR_NUMBER[num.charAt(i)-48]);
}
um=temp.reverse().toString();//反转字符串
um=numReplace(num,"零拾","零");//替换字符串的字符
um=numReplace(num,"零佰","零");//替换字符串的字符
um=numReplace(num,"零仟","零");//替换字符串的字符
um=numReplace(num,"零万","万");//替换字符串的字符
um=numReplace(num,"零亿","亿");//替换字符串的字符
um=umReplace(num,"零零","零");//替换字符串的字符
um=numReplace(num,"亿万","亿");//替换字符串的字符
//如果字符串以零结尾将其除去
if(num.lastIndexOf("零")==num.length()-1){
um=num.substring(0,num.length()-1);
}
returnum;
}
publicstaticStringgetDecimal(Stringnum){
//判断是否包含小数点
if(num.indexOf(".")==-1){
return"";
}
um=um.substring(num.indexOf(".")+1);
//反转字符串
um=newStringBuffer(num).reverse().toString();
//创建一个StringBuffer对象
StringBuffertemp=newStringBuffer();
//加入单位
for(inti=0;i<num.length();i++){
temp.append(STR_UNIT2[i]);
temp.append(STR_NUMBER[num.charAt(i)-48]);
}
um=temp.reverse().toString();//替换字符串的字符
um=umReplace(num,"零角","零");//替换字符串的字符
um=numReplace(num,"零分","零");//替换字符串的字符
um=numReplace(num,"零厘","零");//替换字符串的字符
um=umReplace(num,"零零","零");//替换字符串的字符
//如果字符串以零结尾将其除去
if(num.lastIndexOf("零")==num.length()-1){
um=num.substring(0,um.length()-1);
}
returnnum;
}
publicstaticStringumReplace(Stringnum,StringoldStr,StringnewStr)
{
while(true){
//判断字符串中是否包含指定字符
if(num.indexOf(oldStr)==-1){
break;
}
//替换字符串
num=num.replaceAll(oldStr,newStr);
}
//返回替换后的字符串
returnum;
}
【代码解析】
实现本实例的关键在于以下几点:
_将数字格式化,如果存在小数部分,将其转换为3位小数,精确到厘。
_分别将整数部分与小数部分转换为大写格式,并插入其单位(亿、万、仟??)。
_组合转换后的整数部分与小数部分。
【知识扩展】
DecimalFormat类可以指定格式化模板来格式化浮点数,如保留几位小数。通过调用该类
的format()方法可以使用指定模板来格式化任意浮点数字。
『贰』 EXCEL 单元格里的货币(含小数点)数字格式如何用公式转为文本
=SUBSTITUTE(IF(A2,IF(A2<0,"负",)&TEXT(TRUNC(A2),"[dbnum2]g/通用格式元;[dbnum2]g/通用格式元;")&TEXT(RIGHT(RMB(A2),2),"[>9][dbnum2]0角0分;[>0][dbnum2]00分;整"),"零元"),"零分","整")
『叁』 如何将小写金额转换为大写金额
小写金额转换为大写金额的方法有以下几种:
使用Excel内置函数:
在Excel中,可以直接使用内置的CONVERT函数来实现小写金额转大写。具体操作为输入“=CONVERT(A1, “人民币元”)”,然后将公式拖动到整个单元格区域即可。
也可以使用IF和LEN函数组合来完成。首先需要判断单元格中的小数点位置,根据判断结果分别处理带小数和不带小数的情况,最后将转换后的金额显示在新的单元格中。
手动转换:
将小写金额分为“整金额”和“小数部分”,然后分别将其转换为大写金额。例如,整金额部分按照数位逐级转换,而小数部分则通常转换为“角”和“分”。
使用在线转换工具:
有些网站提供了在线的人民币大小写转换工具。只需在数字金额小写输入框中填入人民币的小写阿拉伯数字金额,然后点击“金额大写转换”按钮即可。
在进行大小写转换时,需要注意以下几点:
确保输入的小写金额是正确的,并且符合人民币的数值规范。
转换时,注意保留小数位数,确保转换后的大写金额与原始金额在数值上保持一致。
转换后的大写金额应符合中文书写规范,例如使用正确的中文数字和单位。
总之,根据具体的需求和场景,可以选择合适的方法进行小写金额到大写金额的转换。如需更多信息,可查阅相关的财务或会计书籍,或者咨询专业的财务或会计人员。
『肆』 电子表格里的数字货币金额怎样转换成中文大写 好看网
在设置单元格格式里选择货币,如果想转为大写,选特殊--中文
大写数字