Java实现人民币大写精讲
想要实现人民币大写,在发票等场景中使用?? 1234.56显示为:壹仟贰佰叁拾肆元伍角陆分,那就往下看看吧!
本程序可以实现 0 到 9999 9999 9999.994 以内的人民币大写转换,精确到分
经典测试数据:
0
希望转换出来的结果为:
零元零角零分
1234
希望转换出来的结果为:
壹仟贰佰叁拾肆元零角零分
9999
希望转换出来的结果为:
玖仟玖佰玖拾玖元零角零分
1234.5
希望转换出来的结果为:
壹仟贰佰叁拾肆元伍角零分
1234.9
希望转换出来的结果为:
壹仟贰佰叁拾肆元玖角零分
1234.56
希望转换出来的结果为:
壹仟贰佰叁拾肆元伍角陆分
1234.99
希望转换出来的结果为:
壹仟贰佰叁拾肆元玖角玖分
1234.994
希望转换出来的结果为:
壹仟贰佰叁拾肆元玖角玖分
1234.999
希望转换出来的结果为:
壹仟贰佰叁拾伍元零角零分
999999999999.999
希望转换出来的结果为:
数据过大,无法进行转换,请重新输入!
程序源码如下,含注释:
package com.tfj.algorithm; import java.util.Scanner; public class RenMingBi {
private boolean zero;
String[] strHan = { "零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖" };
String[] moneyCount = { "", "拾", "佰", "仟" }; RenMingBi() {
zero = false;
} private String[] divide(double digitalRmbValue) {
// 处理整数
long intPart = (long) (digitalRmbValue);
// 处理小数,把小数转换成整数形式处理,并进行四舍五入,此时小数四舍五入之后为100的应该另外加一层处理
long decimalPart = Math
.round((double) Math.round((digitalRmbValue - intPart) * 10000) / 100);
// System.out.println("整数部分为:" + intPart + "小数部分为:" + (digitalRmbValue - intPart));
if (decimalPart == 100) {
intPart += 1;
}
// System.out.println("四舍五入之后整数部分为:" + intPart + "小数部分为:" + decimalPart); String strIntPart = "";
if (intPart == 0)
strIntPart = "0";
else {
strIntPart = "" + intPart;
} String strDecimalPart = "";
if (decimalPart < 10 && decimalPart >= 0)
strDecimalPart = "0" + decimalPart;
else {
strDecimalPart = "" + decimalPart;
}
// 处理输入为0的时候
if (intPart == 0 && decimalPart == 0) {
zero = true;
}
// System.out.println("准换为String后,整数部分为:" + strIntPart + "小数部分为:" + strDecimalPart);
return new String[] { strIntPart, strDecimalPart };
} // 用来转换小数部分
private String transDecimal(String str) {
if (str.equals("100") || str.equals("00")) {
return "零角零分";
} else {
String strResult;
char[] strRmb = new char[20];
strRmb = str.toCharArray();
if (strRmb[0] == '0' && strRmb[1] == '0') {
strResult = "";
} else {
int dm = strRmb[0] - '0';
int dn = strRmb[1] - '0';
strResult = strHan[dm] + "角" + strHan[dn] + "分";
}
return strResult;
}
} // 用来转换整数部分
private String transInt(String str) {
char[] firstFourBitRmb = new char[20];
firstFourBitRmb = str.toCharArray();
int len = firstFourBitRmb.length;
String strResult = "";
for (int i = 0; i < len; i++) {
/**
* 这里开启之后会显示成通俗易懂的格式,例如1001,会转化为:壹仟零壹元,而不是:壹仟零佰零拾壹元, 但我希望得到的是后面这种,因为发票所需显示的就是后面这种
**/ // if (firstFourBitRmb[i] == '0' && i < len) {
// boolean zeroFlag = false;
// while (i < len && firstFourBitRmb[i] == '0') {
// zeroFlag = true;
// i++;
// }
// if (i != len && zeroFlag == true)
// strResult += "零";
// i--;
// } else {
// int m = firstFourBitRmb[i] - '0';
// strResult += strHan[m] + moneyCount[len - i - 1];
// }
int m = firstFourBitRmb[i] - '0';
strResult += strHan[m] + moneyCount[len - i - 1];
}
return strResult;
} public String transComb() {
String[] strTempRmb = new String[2];
double strValue = 0D;
Scanner sc = new Scanner(System.in); System.out.println("请输入具体金额,结果会精确到分:");
strValue = sc.nextDouble();
RenMingBi nr = new RenMingBi();
strTempRmb = nr.divide(strValue);
// 转换小数部分
String result1 = nr.transDecimal(strTempRmb[1]); // 转换整数部分
String result2 = "";
int len = strTempRmb[0].length();
if (len > 12)
return "数据过大,无法进行转换,请重新输入!";
else {
if (len >= 9) {
String strBit1 = strTempRmb[0].substring(0, len - 8);
String strBit2 = strTempRmb[0].substring(len - 8, len - 4);
String strBit3 = strTempRmb[0].substring(len - 4, len);
String strResult1 = nr.transInt(strBit1) + "亿";
String strResult2 = nr.transInt(strBit2) + "万";
String strResult3 = nr.transInt(strBit3) + "元";
result2 = strResult1 + strResult2 + strResult3;
} else if (len >= 5) {
String strBit1 = strTempRmb[0].substring(0, len - 4);
String strBit2 = strTempRmb[0].substring(len - 4, len);
String strResult1 = nr.transInt(strBit1) + "万";
String strResult2 = nr.transInt(strBit2) + "元";
result2 = strResult1 + strResult2;
} else if (len >= 1) {
if (nr.zero == true) {
result2 = "零元";
} else
result2 = nr.transInt(strTempRmb[0]) + "元";
}
return result2 + result1;
}
} public static void main(String[] args) {
RenMingBi rmb = new RenMingBi();
while (true) {
System.out.println(rmb.transComb());
}
}
}
注:输出注释可自行打开,以供测试
运行结果如下:
Java实现人民币大写精讲的更多相关文章
- 深入Java核心 Java内存分配原理精讲
深入Java核心 Java内存分配原理精讲 栈.堆.常量池虽同属Java内存分配时操作的区域,但其适用范围和功用却大不相同.本文将深入Java核心,详细讲解Java内存分配方面的知识. Java内存分 ...
- Java实现人民币大写代码解析
想要实现人民币大写,在发票等场景中使用?? 1234.56显示为:壹仟贰佰叁拾肆元伍角陆分,那就往下看看吧! 本程序可以实现 0 到 9999 9999 9999.994 以内的人民币大写转换,精确到 ...
- Java岗 面试考点精讲(基础篇01期)
即将到来金三银四人才招聘的高峰期,渴望跳槽的朋友肯定跟我一样四处找以往的面试题,但又感觉找的又不完整,在这里我将把我所见到的题目做一总结,并尽力将答案术语化.标准化.预祝大家面试顺利. 术语会让你的面 ...
- Java集合详解8:Java的集合类细节精讲
Java集合详解8:Java集合类细节精讲 今天我们来探索一下Java集合类中的一些技术细节.主要是对一些比较容易被遗漏和误解的知识点做一些讲解和补充.可能不全面,还请谅解. 本文参考:http:// ...
- Java岗 面试考点精讲(基础篇02期)
1. 两个对象的hashCode相同,则equals也一定为true,对吗? 不对,答案见下面的代码: @Override public int hashCode() { return 1; } 两个 ...
- Java岗 面试考点精讲(网络篇03期)
1. OSI七层模型 总结一下: 应用用层按协议打包数据 由传输层加上双方的端口号 由网络层加上双方的IP地址 由链路层加上双方的MAC地址,并将数据拆分成数据帧 数模信号转换并由物理层传输到另一端 ...
- 总结:Java 集合进阶精讲2-ArrayList
知识点:Java 集合框架图 总结:Java 集合进阶精讲1 总结:Java 集合进阶精讲2-ArrayList 初探: ArrayList底层结构是数组,是List接口的 可变数组的实现,所以会占用 ...
- 总结:Java 集合进阶精讲1
知识点:Java 集合框架图 总结:Java 集合进阶精讲1 总结:Java 集合进阶精讲2-ArrayList 集合进阶1---为集合指定初始容量 集合在Java编程中使用非常广泛,当容器的量变得非 ...
- java高级精讲之高并发抢红包~揭开Redis分布式集群与Lua神秘面纱
java高级精讲之高并发抢红包~揭开Redis分布式集群与Lua神秘面纱 redis数据库 Redis企业集群高级应用精品教程[图灵学院] Redis权威指南 利用redis + lua解决抢红包高并 ...
随机推荐
- 第十篇、自定义UIBarButtonItem和UIButton block回调
// 自定义导航栏左边按钮 self.navigationItem.leftBarButtonItem = [JQBlockedBarButtonItem blockedBarButtonItemWi ...
- percent-encode 百分号编码
原文地址:http://www.imkevinyang.com/2009/08/详解javascript中的url编解码.html 摘要 URI(统一资源标识)编解码 为什么需要编码 哪些需要编码 如 ...
- C#变量初始化问题:字段初始值无法引用非静态字段、方法或属性
http://www.cnblogs.com/bluestorm/p/3432190.html 问题:字段初始值设定项无法引用非静态字段.方法或属性的问题 下面代码出错的原因,在类中定义的字段为什么不 ...
- spring Cache注解
如下:不能将缓存注解加在listCate(boolean isShowHide)方法上 因为spring是使用AOP的方法获取缓存,在一个bean中再去调用别一个方法,不会应用缓存 @Cacheabl ...
- NOIP201501&&02
NOIP201501金币 试题描述 国王将金币作为工资,发放给忠诚的骑士.第一天,骑士收到一枚金币:之后两天(第二天和第三天) ,每天收到两枚金币:之后三天(第四.五.六天) ,每天收到三枚金币:之后 ...
- 九度OJ 1351 数组中只出现一次的数字
题目地址:http://ac.jobdu.com/problem.php?pid=1351 题目描述: 一个整型数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字. 输 ...
- <UNIX环境高级编程>文件共享及fork函数
UNIX系统支持在不同进程间共享打开文件.内核使用3种数据结构表示打开文件,它们之间的关系决定了文件共享方面一个进程对另一个进程可能产生的影响. 内核维持了3个表,即进程表,文件表和v节点表.具体如下 ...
- 通过LDF文件实现日志回滚将数据恢复(转)
该方法数据库恢复(www.db-recovery.com)思路 1. 创建数据TEST 2. 创建表TEMP_01 3. 在表TEMP_01中插入100条数据 4. 备份现有的数据库 5. 再次向表T ...
- ajax 请求二进制流 图片 文件 XMLHttpRequest 请求并处理二进制流数据 之最佳实践
写在前面 :从提出需求到完美的解决问题,实现过程是曲折的. 需求:在前(web client)后(Restful Service)端完全解耦的模式框架下,webclient需要请求 Service 返 ...
- MongoDB入门三步曲1--安装、基本操作
mongodb 基本操作 目录 mongodb安装 mongod启动 mongo shell启动 mongod 停止 mongodb基本操作:CRUD 数据插入 数据查询 数据更新 数据删除 集合删除 ...