package practice;

import java.util.Arrays;

/**
* 数字与中文数字互转(最大处理数字不超过万兆即:9999999999999999.9999)
* @author Archimedes
* @Date 6 7 19
*/
public class ChineseNumberAndNumber { private static final char NUMBER_CONSTRAINT[] = {'9', '8', '7', '6', '5', '4', '3', '2', '1', '0', '.'}; private static final String[] DECIMAL_UNIT = {"角", "分", "厘", "毫"}; private static final String[] CHINESE_NUMBER = {"零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"}; private static final String[] INTEGER_UNIT = {"", "万", "亿", "兆"}; private static final String[] INTEGER_UNIT1 = {"", "拾", "佰", "仟"}; /**
* 数字转中文数字
* @param number
* @return
*/
public static String numberToChineseNumber(String number) {
//数字有效性判断
//先判断number中的数字是否在NUMBER_CONSTRAINT[]中
int quantity = NUMBER_CONSTRAINT.length - 1;
for (int i = 0; i < number.length(); i++) {
char unit = number.charAt(i);
for (int j = 0; j < NUMBER_CONSTRAINT.length; j++) {
if (unit == NUMBER_CONSTRAINT[j]) break;
if (j == quantity) return "请输入有效数字";
}
}
//再判断number中小数点是否不超过1个且小数点不在第一位和最后一位
int quantity1 = 0;
for (int i = 0; i < number.length(); i++) {
if ('.' == number.charAt(i) && (i == 0 || i == number.length() - 1)) return "1请输入有效数字";
if ('.' == number.charAt(i)) {
++quantity1;
if (quantity1 == 2) return "2请输入有效数字";
}
}
//最后做数字范围的有效判断,并且把诸如0.000000000000000的数字转换为0
if (quantity1 == 0) {
number = headNumberIsZero(number);
if (number.length() > 16) return "3请输入有效数字";
} else {
String[] split = number.split("[.]");
//处理整数部分
split[0] = headNumberIsZero(split[0]);
if (split[0].length() > 16) return "4请输入有效数字";
//处理小数部分
if (split[1].length() > 4) {
for (int i = 4; i < split[1].length(); i++) {
if ('0' != split[1].charAt(i)) return "5请输入有效数字";
}
split[1] = split[1].substring(0, 4);
}
for (int i = split[1].length() - 1; i >= 0; i--) {
if ('0' == split[1].charAt(i)) split[1] = split[1].substring(0, i);
else break;
}
//合并整数与小数
if (split[1].isEmpty()) number = split[0];
else number = split[0] + "." + split[1];
}
//数字有效性判断完毕 //数字转中文数字
String[] result = {"", ""};
String[] split = number.split("[.]");
//处理小数部分
if (split.length == 2) {
int c = 0; //定义标识用于判断前一位是否为0
for (int i = 0; i < split[1].length(); i++) {
if (c == 0 && ('0' == split[1].charAt(i))) {
result[1] += CHINESE_NUMBER[0];
c = 1;
} else if ('0' != split[1].charAt(i)) {
result[1] += (CHINESE_NUMBER[Integer.parseInt(String.valueOf(split[1].charAt(i)))] + DECIMAL_UNIT[i]);
c = 0;
}
}
}
//处理整数部分
//把整数部分从左到右每4个一组放入数组
String[] integerPart = new String[(split[0].length() - 1) / 4 + 1];
for (int i = split[0].length() - 1; i >= 0; i -= 4) {
if (i - 3 >= 0) integerPart[i / 4] = split[0].substring(i - 3, i + 1);
else integerPart[i / 4] = split[0].substring(0, i + 1);
}
System.out.println(Arrays.toString(integerPart));
//转换
int length = integerPart.length;
int c = 0; //用于判断前一位是否为0
if (length > 1) {
int l = 1; ////用于判断上一次计数单位是否全为0(0表示全为0)
for (int i = 0; i < integerPart.length; i++) {
int x = 0; //用于判断计数单位是否全为0
int length1 = integerPart[i].length();
for (int j = 0; j < length1; j++) {
if (c == 0 && '0' != integerPart[i].charAt(j)) {
String temp = CHINESE_NUMBER[Integer.parseInt(String.valueOf(integerPart[i].charAt(j)))]
+ INTEGER_UNIT1[length1 - 1 -j];
result[0] += temp;
x = 1;
} else if ('0' == integerPart[i].charAt(j)) {
c = 1;
} else if (c == 1 && j == 0 && '0' != integerPart[i].charAt(j)) {
if (l == 0) result[0] += "零";
String temp = CHINESE_NUMBER[Integer.parseInt(String.valueOf(integerPart[i].charAt(j)))]
+ INTEGER_UNIT1[length1 - 1 -j];
result[0] += temp;
c = 0; x = 1;
} else if (c == 1 && j != 0 && '0' != integerPart[i].charAt(j)) {
String temp = "零" + CHINESE_NUMBER[Integer.parseInt(String.valueOf(integerPart[i].charAt(j)))]
+ INTEGER_UNIT1[length1 - 1 -j];
result[0] += temp;
c = 0; x = 1;
}
}
l = x; //把此次循环的计数单位是否全为0的结果赋值给变量,用于下次循环判断
if (x == 1) result[0] += INTEGER_UNIT[length - 1 - i];
}
result[0] += "元";
} else {
int length1 = integerPart[0].length();
for (int i = 0; i < length1; i++) {
if (c == 0 && ('0' != integerPart[0].charAt(i))) {
String temp = CHINESE_NUMBER[Integer.parseInt(String.valueOf(integerPart[0].charAt(i)))]
+ INTEGER_UNIT1[length1 - 1 - i];
result[0] += temp;
} else if ('0' == integerPart[0].charAt(i)) {
if (length1 == 1) {
result[0] += "零";
}
c = 1;
} else if (c == 1 && ('0' != integerPart[0].charAt(i))) {
String temp = "零" + CHINESE_NUMBER[Integer.parseInt(String.valueOf(integerPart[0].charAt(i)))]
+ INTEGER_UNIT1[length1 - 1 - i];
result[0] += temp;
c = 0;
}
}
result[0] += "元";
}
if (split.length == 1) {
result[0] += "整";
return result[0];
} else {
if ("零元".equals(result[0])) return result[1];
else return result[0] + result[1];
}
//数字转中文数字完毕
} /**
* 把数字的前几个连续的0去掉,但数字如全为0则保留1个
* @param number
* @return
*/
private static String headNumberIsZero(String number) {
try {
if ('0' == number.charAt(0)) return headNumberIsZero(number.substring(1));
else return number;
} catch (IndexOutOfBoundsException e) {
return "0";
}
} private static String headNumberIsZero1(String number) {
if (number.isEmpty()) return "0";
if ('0' == number.charAt(0)) return headNumberIsZero(number.substring(1));
else return number;
} private static String headNumberIsZero2(String number) {
if ('0' != number.charAt(0)) return number;
else {
for (int i = 1; i < number.length(); i++) {
if ('0' != number.charAt(i)) {
number = number.substring(i);
break;
} else if (i == number.length() -1) number = "0";
}
}
return number;
} public static void main(String[] args) {
String number = numberToChineseNumber("64646405000.033");
System.out.println(number);
} }

JAVA处理数字与中文数字互转(最大处理数字不超过万兆即:9999999999999999.9999)的更多相关文章

  1. Java中过滤出字母、数字和中文的正则表达式

    1.Java中过滤出字母.数字和中文的正则表达式 (1)过滤出字母的正则表达式 [^(A-Za-z)] (2)过滤出数字的正则表达式 [^(0-9)] (3)过滤出中文的正则表达式 [^(\\u4e0 ...

  2. java 数字转中文

    java代码 数字转中文,该方法只做了对int型整数的转换 private static String numberToChinese(int number) { String[] numbers = ...

  3. java中用正则表达式判断中文字符串中是否含有英文或者数字

    public static boolean includingNUM(String str)throws  Exception{ Pattern p  = Pattern.compile(" ...

  4. AJPFX总结关于Java中过滤出字母、数字和中文的正则表达式

    1.Java中过滤出字母.数字和中文的正则表达式 (1)过滤出字母的正则表达式      [^(A-Za-z)] (2) 过滤出 数字 的正则表达式   [^(0-9)] (3) 过滤出 中文 的正则 ...

  5. Java正则表达式过滤出字母、数字和中文

    原文:http://blog.csdn.net/k21325/article/details/54090066 1.Java中过滤出字母.数字和中文的正则表达式 (1)过滤出字母的正则表达式 [^(A ...

  6. java实现数字转中文大写

    package cn.aikang.ChineseC; import java.util.Scanner; /** * @Description: TODO(这里用一句话描述这个类的作用) * @Au ...

  7. 使用Java将阿拉伯数字转换为中文数字(适配小数转换)

    Java数字转换工具类 简介 该工具类可以将整数.小数.负数转换为中文的数字,如: 0 --> 零 1 --> 一 2.1 --> 二点一 -2.1 --> 负二点一 具体代码 ...

  8. java判断字符串是否为数字或中文或字母

     个人认为最好的方法 *各种字符的unicode编码的范围:     * 汉字:[0x4e00,0x9fa5](或十进制[19968,40869])     * 数字:[0x30,0x39](或十进制 ...

  9. textbox只能输入数字或中文的常用正则表达式和验证方法

    验证数字的正则表达式集 验证数字:^[0-9]*$ 验证n位的数字:^\d{n}$ 验证至少n位数字:^\d{n,}$ 验证m-n位的数字:^\d{m,n}$ 验证零和非零开头的数字:^(0|[1-9 ...

随机推荐

  1. kubenetes安装

    master节点主要由四个模块组成: APIServer   提供了资源操作的唯一入口,任何对资源进行增删改查的操作都要交给APIServer处理后再提交给etcd.kubectl就是对api ser ...

  2. iOS笔试题03

    1. When to use NSMutableArray and when to use NSArray? 1> 当数组元素需要动态地添加或者删除时,用NSMutableArray 2> ...

  3. python 优雅的解析 jsonp

    一段 jsonp 格式数据 mtopjsonpweexcb1({"api":"mtop.taobao.idle.recycle.nextspunav.get", ...

  4. java类加载全过程

    引用:http://blog.csdn.net/haluoluo211/article/details/49908463 http://www.cnblogs.com/pengfeiliu/p/442 ...

  5. 如何用IDEA创建springboot(maven)并且整合mybatis连接mysql数据库和遇到的问题

    一.New->Project 二.点击next 三.在Group栏输入组织名,Artifact就是项目名.选择需要的java版本,点击next 四.添加需要的依赖 在这里我们也可以添加sql方面 ...

  6. HTTP最常见的响应头

    HTTP最常见的响应头如下所示: l         Allow:服务器支持哪些请求方法(如GET.POST等): l         Content-Encoding:文档的编码(Encode)方法 ...

  7. LayUI笔记

    LayUI  经典模块化前端框架,低门槛开箱即用的前端 UI 解决方案.   其他UI框架:     Bootstrap,Element, EasyUI,LayUI 等等 LayUI使用  Layui ...

  8. 剑指offer58:对称的二叉树。判断一颗二叉树是不是对称的,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的

    1 题目描述 请实现一个函数,用来判断一颗二叉树是不是对称的.注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的. 2 思路和方法 定义一种遍历算法,先遍历右子结点再遍历左子结点:如对称先序 ...

  9. homestead的创建和使用

    1.下载vistualbox和vagrant并安装 2.安装了git的话就在想设置的目录或者文件夹下用git命令执行vagrant box add laravel/homestead,或者用cmd命令 ...

  10. 体验Managed Extensibility Framework精妙的设计

    MEF(Managed Extensibility Framework)是.NET Framework 4.0一个重要的库,Visual Studio 2010 Code Editor的扩展支持也是基 ...