今天主要写了这个金额转换的方法,这个金额转换最大支持九仟万亿兆以内的金额转换,最小支持0.0009厘的金额转换,应该可以对现在的金额进去转换运算了
。
因为金额支持过大,所以我测试金额肯定不全,如有错误,还请大家指正,
。
我在以后还会慢慢完善这个字符串工具类的~~
package com.jynine.main;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
* 金额转换 支持99999999999999999999999999999999.9999以内的金额换算,
* 应该够目前的金额使用了。
* @author jynine
*
*/
public class MoneyConvert {
private static String[] NUMBER= {"零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"};
private static String[] UN = {"","万","亿","兆"};
private static String[] CH_1 ={"仟","","拾","佰"};
private static String[] CH_2 = {"角","分","毫","厘"};
private static int ZERO = 0;
private static Pattern FLOATPATTERN = Pattern.compile("^(-?\\d+)(\\.\\d{1,4})?$");
/**
* 金额转换(只精确到厘)
* @param num
* @return
* @throws Exception
*/
public static String convert(String money) throws Exception{
if(isEmpty(money == null ? null : money.replaceAll(" ", ""))){
throw new Exception("金额为空!");
}else{
money = money.replaceAll(" ", "");
if(!isFloat(money)){
throw new Exception("金额格式不正确!");
}else{
StringBuffer sb = new StringBuffer();
String pointMoney = "";
sb.append("¥");
if(money.contains(".")){
pointMoney = money.substring(money.indexOf(".")+1, money.length());
money = money.substring(0, money.indexOf("."));
}
if(money.length() > 32){
throw new Exception("目前只支持32位及以下的金额!");
}else{
int zeroCount = 0;
recursionMoney(sb, money, zeroCount);
boolean tag = true;
if(money.length() == 1 && money.equals("0")){
zeroCount = 0;
tag = false;
}else{
sb.append("元");
}
calPoint(sb,pointMoney,zeroCount,tag);
sb.append("整");
return sb.toString();
}
}
}
}
/**
* 递归换算money
* @param sb
* @param money
* @param zeroCount
*/
private static void recursionMoney(StringBuffer sb,String money,int zeroCount){
int len = money.length();
int end = 8;
if(len%8 != 0){
end = len%8;
}
calMoney(sb, money.substring(0, end), zeroCount);
if(len > 8){
sb.append(UN[(((len-1)/8))%2==0?3:2]);
}
money = money.substring(end, money.length());
if(isNotEmpty(money) && money.length()>0){
recursionMoney(sb, money, zeroCount);
}
}
/**
* 分开计算money
* @param sb
* @param money
* @return
*/
private static StringBuffer calMoney(StringBuffer sb,String money,int zeroCount){
int len = money.length();
String s = "";
int n = 0;
for (int i = 0; i < len; i++) {
s = money.substring(i, i+1);
n = Integer.parseInt(s);
if((len-i)%4 == 1){
if(n != ZERO){
if(zeroCount > 0){
sb.append(NUMBER[0]);
}
sb.append(NUMBER[n] + CH_1[(len-i)%4]);
zeroCount = 0;
}else{
zeroCount ++;
}
if(zeroCount < 4){
sb.append(UN[(len-i)/4]);
}
}else{
if(n != ZERO){
if(zeroCount > 0){
sb.append(NUMBER[0]);
}
sb.append(NUMBER[n]+CH_1[(len-i)%4]);
zeroCount = 0;
}else{
zeroCount ++;
}
}
}
return sb;
}
/**
* 小数点金额转换
* @param sb
* @param pointMoney
* @param zeroCount
* @param tag
*/
private static void calPoint(StringBuffer sb,String pointMoney,int zeroCount,boolean tag){
String s = "";
int n = 0;
if(isNotEmpty(pointMoney)){
for (int i = 0; i < pointMoney.length(); i++) {
if(i>3){
break;
}
s = pointMoney.substring(i, i+1);
n = Integer.parseInt(s);
if(n == ZERO){
if(tag){
zeroCount ++;
}
}else{
if(zeroCount > 0 && i != 0){
sb.append(NUMBER[0]);
}
tag = true;
sb.append(NUMBER[n]+CH_2[i]);
zeroCount = 0;
}
}
}
}
/**
* 判断字符是否是空
* @param s
* @return
*/
public static boolean isEmpty(String str){
if(str != null && str!= ""){
return false;
}else{
return true;
}
}
/**
* 判断字符是否为非空
* @param str
* @return
*/
public static boolean isNotEmpty(String str){
if(str != null && str!= ""){
return true;
}else{
return false;
}
}
/**
* 验证是否是float类型
* @param input
* @return
*/
public static boolean isFloat(String input){
Matcher matcher = FLOATPATTERN.matcher(input);
return matcher.matches();
}
public static void main(String[] args) throws Exception {
System.out.println(convert("99999999999999999999999999999999.9999"));
System.out.println(convert("10 0010.29"));
}
}
分享到:
相关推荐
System.out.println("转换后的日期字符串为:" + strDate); } } ``` 在这个示例中,我们定义了一个名为`dateToStr`的方法,它接受一个`Date`类型的参数,并返回一个字符串。我们使用了`SimpleDateFormat`的构造...
java编程中对字符串的各种方式的处理,包括(空字符串处理、判断是否是空字符串 null和"" 都返回 true、 把string array or list用给定的符号symbol连接成一个字符串、 判定第一个字符串是否等于的第二个字符串中的某...
### Java.util.Date与Java.sql.Date互转及字符串转换为日期时间格式 #### 一、Java.util.Date与Java.sql.Date的基本概念 在Java编程语言中,处理日期和时间时经常使用到`java.util.Date`和`java.sql.Date`这两个类...
本项目名为"C语言实现String字符串及其函数stringUtil",主要关注的是如何在C语言环境中自定义处理字符串的函数,以扩展标准库中提供的功能。通过分析`stringUtil.c`源代码和`stringUtil.h`头文件,我们可以了解一些...
Java提供了多种方法来生成随机字符串,主要包括使用`java.util.Random`类和`java.security.SecureRandom`类。其中,`SecureRandom`类提供了一种更加安全的方式来生成随机数,它适合于安全性要求较高的应用场合。 ##...
自己整理的StringUtil ,字符串处理工具类,很全面的方法,对象之间的数据转换
在Java编程语言中,分割字符串是一项常见的操作,它允许我们将一个长字符串分解成多个子字符串,每个子字符串对应原字符串中的某个部分。这通常通过使用`split()`方法来实现,该方法是Java `String`类的一个成员。在...
USER_NAME to UserName,USER_NAME to userName,转义正则特殊字符 ,获取字符串长度汉字占两个字符,验证号码是否合法 (是否是手机号或者电话号码),将经纬度转换成字符串,将字符转换成二进制,将二进制字符串...
首先,我们要明白Java中的字符串是`String`类的对象,它提供了丰富的API用于字符串的处理。例如,我们可以使用`substring()`方法来截取字符串的一部分,但这并不适用于提取括号内的内容,因为我们需要识别开括号和闭...
Java字符串工具类。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
`StringUtil`是一个常见的Java工具类,它包含了大量用于处理字符串的方法,可以极大地简化字符串操作,提高代码的可读性和效率。在Java开发中,我们经常会遇到对字符串进行各种操作的需求,如检查空值、分割、连接、...
在Java编程中,工具类(Util Classes)是程序员日常工作中不可或缺的部分,它们提供了一系列静态方法,用于执行常见的任务,如JSON解析、日期处理、字符串操作等。以下是对标题和描述中涉及的知识点的详细说明: 1....
本次实验旨在深化理解Java中的数组与字符串操作,聚焦于`String`类与`StringBuffer`类的掌握,包括它们的常用方法、相等性判断的不同方式、数组的创建及引用机制,以及`Arrays`类的静态方法应用。实验通过具体的编程...
10. **`toCharArray()` 方法**:将字符串转换为字符数组。 ```java String text = "tobeornottobe"; char[] textArray = text.toCharArray(); // 转换成字符数组 ``` 11. **`getChars()` 方法**:将字符串的...
3. **构建新字符串**:排序完成后,使用`Character.toString(char)`或`new String(char[])`将字符数组转换回字符串。 以下是一个简单的示例代码: ```java import java.util.Arrays; public class Zifuchuan { ...
- `java.util.Arrays.toString()`:将字符数组转换为可读的字符串表示。 - `java.text.DecimalFormat`:用于数字的格式化输出。 以上只是Java字符串操作的一小部分,实际开发中还有许多其他方法和特性,如国际化...
- 使用`parse()`方法解析字符串为`java.util.Date`对象。 - 使用`java.util.Date`对象的`getTime()`方法获取毫秒值,然后创建`java.sql.Date`对象并返回。 3. **异常处理**: - 在方法内部捕获`ParseException`...
在Java编程中,将文本内容中的符合URL格式的字符串转换为超链接是一项常见的需求,特别是在处理用户生成内容或网络爬虫应用中。本教程将详细讲解如何使用Java实现这一功能,主要涉及URL正则表达式匹配和字符串处理...
在Java编程语言中,字符串(String)是至关重要的数据类型,用于存储和操作文本。字符串类提供了丰富的API,使得处理字符串变得高效且灵活。本篇将深入探讨Java中的字符串、正则表达式及其在实际编程中的详细实例代码...