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实现人民币大写精讲
想要实现人民币大写,在发票等场景中使用?? 1234.56显示为:壹仟贰佰叁拾肆元伍角陆分,那就往下看看吧! 本程序可以实现 0 到 9999 9999 9999.994 以内的人民币大写转换,精确到 ...
- Java生产消费者模型——代码解析
我们将生产者.消费者.库存.和调用线程的主函数分别写进四个类中,通过抢夺非线程安全的数据集合来直观的表达在进行生产消费者模型的过程中可能出现的问题与解决办法. 我们假设有一个生产者,两个消费者来共同抢 ...
- java笔记 -- java简单结构代码解析及注释
结构代码解析 public class FirstSample { public static void main(String[] args) { System.out.println(2.0-1. ...
- java集合框架之java HashMap代码解析
java集合框架之java HashMap代码解析 文章Java集合框架综述后,具体集合类的代码,首先以既熟悉又陌生的HashMap开始. 源自http://www.codeceo.com/arti ...
- Java二进制指令代码解析
http://www.blogjava.net/DLevin/archive/2011/09/13/358497.html http://blog.csdn.net/sum_rain/article/ ...
- java代码解析二维码
java代码解析二维码一般步骤 本文采用的是google的zxing技术进行解析二维码技术,解析二维码的一般步骤如下: 一.下载zxing-core的jar包: 二.创建一个BufferedImage ...
- java 将一个正整数翻译成人民币大写的读法
程序如下: import java.lang.StringBuffer; /** 给定一个浮点数,将其装换成人民币大写的读法 88.5:捌十捌元零伍角 */ public class Num2Rmb ...
- Java 实现对Sql语句解析
原文地址:http://www.cnblogs.com/zcftech/archive/2013/06/10/3131286.html 最近要实现一个简易的数据库系统,除了要考虑如何高效的存储和访问数 ...
- Java中的static关键字解析
Java中的static关键字解析 static关键字是很多朋友在编写代码和阅读代码时碰到的比较难以理解的一个关键字,也是各大公司的面试官喜欢在面试时问到的知识点之一.下面就先讲述一下static关键 ...
随机推荐
- postgresql jsonb类型查询
select * from (select * from ud_order where user_id=10 and status=2unionselect * from ud_order where ...
- Simple screenshot that explains the non-static invocation.
Here is the code: /* Instance invocation in the memory: */ package kju.obj; import static kju.print. ...
- Initializer block.
Ref: Initializing Fields Instance initializers are permitted to refer to the current object via the ...
- move file create directory.
If we want to move file to the directory that does not exist,and if we perform a File.Move,it will r ...
- jquery选择器的使用方式
1.基本选择器 选择器 描述 返回 示例 代码说明 1 id选择器 根据指定的id匹配元素 单个元素 $("#one").css("background", ...
- 不用Google Adsense的84个赚钱方法
这是一个关于网络广告商和网络销售的汇总列表,可以用来为您的网站或博客赚点钱.广告商都是英文的,加入广告请确认其是否支持中国地区支持,不支持的话就不必加入了. Chitika : 购物中心旗帜广告. ( ...
- 【POJ1568】【极大极小搜索+alpha-beta剪枝】Find the Winning Move
Description 4x4 tic-tac-toe is played on a board with four rows (numbered 0 to 3 from top to bottom) ...
- yzoi1109&&viojs1042最小步数的一点看法——回文数
Description - 问题描述 有一天,雄霸传授本人风神腿法第一式:捕风捉影..............的步法(弟子一:堂主,你大喘气呀.风:你给我闭嘴.)捕风捉影的关键是换气(换不好就会大喘气 ...
- openerp 中如何方便对搜索时间段
以前为了方便的搜索时间区间,经常用wizard对方式,设置开始 结束时间,需要做大量对代码工作, 今天看了search view对组成, 可以用2个filter_domain 来做, 这样用户需要输 ...
- Win10的革新与突破
7月29号win10全球发布,作为微软最后一款操作系统,它会有那些令人期待的革新,作为一个互联网后现代时代,这款操作系统又会融入什么特别元素? 抱着期待,更新了win10后,我花了大概一天的时间,亲身 ...