java实现整数转化为中文大写金额的方法

在日常生活中,我们经常会将阿拉伯数字转化为中文大写的情况:"零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖", "拾", "佰", "仟", "万", "亿",因此自己就编写一个类,实现该功能的转化。
实现过程:
对于这个问题的实现,我们首先把数字按四位一个拆开(符合我们读数字的习惯),然后对这四位数,做出他的读法,具体代码如下:

private static String getNumberStr1000 (int num) {
 if (num > 9999 || num < 0) {
  return "";
 }
 int q = num / 1000;
 int b = (num / 100) % 10;
 int s = (num / 10) % 10;
 int g = num % 10;
 StringBuffer sb = new StringBuffer();
 //千
 if (q > 0) {
  sb.append(NUMBER1[q]);
  sb.append(NUMBER2[3]);
 }
 //百
 if (b > 0) {
  sb.append(NUMBER1[b]);
  sb.append(NUMBER2[2]);
 } else {
  if (q != 0) {
   sb.append(NUMBER2[0]);
  }
 }
 //十
 if (s > 0) {
  sb.append(NUMBER1[s]);
  sb.append(NUMBER2[1]);
 } else {
  if (b != 0) {
   sb.append(NUMBER2[0]);
  }
 }
 //个
 if (g > 0) {
  sb.append(NUMBER1[g]);
 }
 return sb.toString();
}

下面我们只需要在编写一个方法,实现每个四位数的读法以及对应的单位即可,具体代码如下:

public static String getNumberStr(int num) {
 if (num < 0) {
  return "";
 }
 if (num == 0) {
  return NUMBER1[0];
 }
 int split = 10000;
 int y = num / (split * split);
 int w = (num / split) % split;
 int g = num % split;
 StringBuffer sb = new StringBuffer();
 //亿
 if (y > 0) {
  sb.append(getNumberStr1000(y));
  sb.append(NUMBER2[5]);
 }
 //万
 if (w > 999) {
  sb.append(getNumberStr1000(w));
  sb.append(NUMBER2[4]);
 } else {
  if (w > 0) {
   if (y != 0) {
    sb.append(NUMBER2[0]);
   }
   sb.append(getNumberStr1000(w));
   sb.append(NUMBER2[4]);
  }
 }
 //万以下
 if (g > 0) {
  if (w != 0) {
   if (g > 999) {
    sb.append(getNumberStr1000(g));
   } else {
    sb.append(NUMBER2[0]);
    sb.append(getNumberStr1000(g));
   } 

  } else {
   if (y != 0) {
    sb.append(NUMBER2[0]);
   }
   sb.append(getNumberStr1000(g));
  }
 }
 return sb.toString();
}

完整源代码:

 /**
 *@Description:
 */
package com.lulei.util; 

public class NumberUtil {
 private static String[] NUMBER1 = {"零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"};
 private static String[] NUMBER2 = {"零", "拾", "佰", "仟", "万", "亿"}; 

 /**
  * @param num
  * @return
  * @Author:lulei
  * @Description:将数字转化为大写
  */
 public static String getNumberStr(int num) {
  if (num < 0) {
   return "";
  }
  if (num == 0) {
   return NUMBER1[0];
  }
  int split = 10000;
  int y = num / (split * split);
  int w = (num / split) % split;
  int g = num % split;
  StringBuffer sb = new StringBuffer();
  //亿
  if (y > 0) {
   sb.append(getNumberStr1000(y));
   sb.append(NUMBER2[5]);
  }
  //万
  if (w > 999) {
   sb.append(getNumberStr1000(w));
   sb.append(NUMBER2[4]);
  } else {
   if (w > 0) {
    if (y != 0) {
     sb.append(NUMBER2[0]);
    }
    sb.append(getNumberStr1000(w));
    sb.append(NUMBER2[4]);
   }
  }
  //万以下
  if (g > 0) {
   if (w != 0) {
    if (g > 999) {
     sb.append(getNumberStr1000(g));
    } else {
     sb.append(NUMBER2[0]);
     sb.append(getNumberStr1000(g));
    } 

   } else {
    if (y != 0) {
     sb.append(NUMBER2[0]);
    }
    sb.append(getNumberStr1000(g));
   }
  }
  return sb.toString();
 } 

 /**
  * @param num
  * @return
  * @Description:对万以下的数字进行大小写转化
  */
 private static String getNumberStr1000 (int num) {
  if (num > 9999 || num < 0) {
   return "";
  }
  int q = num / 1000;
  int b = (num / 100) % 10;
  int s = (num / 10) % 10;
  int g = num % 10;
  StringBuffer sb = new StringBuffer();
  //千
  if (q > 0) {
   sb.append(NUMBER1[q]);
   sb.append(NUMBER2[3]);
  }
  //百
  if (b > 0) {
   sb.append(NUMBER1[b]);
   sb.append(NUMBER2[2]);
  } else {
   if (q != 0) {
    sb.append(NUMBER2[0]);
   }
  }
  //十
  if (s > 0) {
   sb.append(NUMBER1[s]);
   sb.append(NUMBER2[1]);
  } else {
   if (b != 0) {
    sb.append(NUMBER2[0]);
   }
  }
  //个
  if (g > 0) {
   sb.append(NUMBER1[g]);
  }
  return sb.toString();
 } 

 public static void main(String[] args) {
  // TODO Auto-generated method stub
  int i = 1;
  System.out.println(i + "--" + NumberUtil.getNumberStr(i));
  i = 1001;
  System.out.println(i + "--" + NumberUtil.getNumberStr(i));
  i = 100101;
  System.out.println(i + "--" + NumberUtil.getNumberStr(i));
  i = 10100101;
  System.out.println(i + "--" + NumberUtil.getNumberStr(i));
  i = 1234567890;
  System.out.println(i + "--" + NumberUtil.getNumberStr(i));
 } 

}

测试运行结果:

希望本文所述对大家学习java程序设计有所帮助。

(0)

相关推荐

  • 谈谈Java中整数类型(short int long)的存储方式

    在java中的整数类型有四种,分别是 byte  short int long 其中byte只有一个字节 0或1,在此不详细讲解. 其他的三种类型如下: 1. 基本类型:short 二进制位数:16 包装类:java.lang.Short 最小值:Short.MIN_VALUE=-32768 (-2的15此方) 最大值:Short.MAX_VALUE=32767 (2的15次方-1) 2. 基本类型:int 二进制位数:32 包装类:java.lang.Integer 最小值:Integer.M

  • Java将一个正整数分解质因数的代码

    程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成: 1.如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可. 2.如果n <> k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你,重复执行第一步. 3.如果n不能被k整除,则用k+1作为k的值,重复执行第一步. 程序设计: public class exp2{ public exp2(){} public void fengjie(int n){ for(int i=2;i<=

  • java中字符串转整数及MyAtoi方法的实现

    java中字符串转整数及MyAtoi方法的实现 该题虽然和我们正常使用的字符串转整数的API中函数不一致,但是通过增加了很多额外的边界或者异常处理,可以锻炼算法思维的敏锐性和处理边界异常等问题的能力. 思路:字符串题一般考查的都是边界条件.特殊情况的处理.所以遇到此题一定要问清楚各种条件下的输入输出应该是什么样的. 这里已知的特殊情况有: 能够排除首部的空格,从第一个非空字符开始计算 允许数字以正负号(+-)开头 遇到非法字符便停止转换,返回当前已经转换的值,如果开头就是非法字符则返回0 在转换

  • Java求两个正整数的最大公约数和最小公倍数

    题目:输入两个正整数m和n,求其最大公约数和最小公倍数. 程序分析:利用辗除法. 最大公约数: public class CommonDivisor{ public static void main(String args[]) { commonDivisor(24,32); } static int commonDivisor(int M, int N) { if(N<0||M<0) { System.out.println("ERROR!"); return -1; }

  • java中最大的整数用法分析

    本文实例讲述了java中最大的整数用法.分享给大家供大家参考,具体如下: 8种基本数据类型中,long类型所能表示的整数范围是最大的,但还是有限的.另外,基本数据类型中的整数还有一个问题,那就是不是每个数都能够正确的取负数.例如,对int型而言,"-2147483648"取负就不能得到正确的结果,对其他整数类型也有这个问题. 为了解决这些问题,Java中专门提供了用来进行不限制大小的整数计算的类--java.math.BigInteger.该类可以对任意大小的整数进行操作,不过在进行计

  • Java输入三个整数并把他们由小到大输出(x,y,z)

    题目:输入三个整数x,y,z,请把这三个数由小到大输出. 程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果x> y则将x与y的值进行交换,然后再用x与z进行比较,如果x> z则将x与z的值进行交换,这样能使x最小. 程序设计: import java.util.*; public class test { public static void main (String[]args){ int i=0; int j=0; int k=0; int x=0; System.out.

  • java整数(秒数)转换为时分秒格式的示例

    整数(秒数)转换为时分秒格式(xx:xx:xx) 复制代码 代码如下: // a integer to xx:xx:xx    public static String secToTime(int time) {        String timeStr = null;        int hour = 0;        int minute = 0;        int second = 0;        if (time <= 0)            return "00

  • JAVA中IP和整数相互转化的方法

    本文实例讲述了JAVA中IP和整数相互转化的方法.分享给大家供大家参考.具体分析如下: 一.基本知识点 IP --> 整数: 把IP地址转化为字节数组 通过左移位(<<).与(&).或(|)这些操作转为int 整数 --> IP: 将整数值进行右移位操作(>>>),右移24位,再进行与操作符(&)0xFF,得到的数字即为第一段IP. 将整数值进行右移位操作(>>>),右移16位,再进行与操作符(&)0xFF,得到的数字即为

  • 详解Java判断是否是整数,小数或实数的正则表达式

    经常会遇到这样的情况,需要判断一个字符串是否是一个合法的数,包括整数,小数或者实数. 网上查到很多文章大多是判断这个字符串是否全为数字,比如下面这段来自StringUtils的代码,可以看到,13.2这样的数字实际上会返回false,可是,他的确是一个数字. public static boolean isNumeric(String str) { if (str == null) { return false; } int sz = str.length(); for (int i = 0;

  • Java根据正整数的位数并逆序打印出各位数字

    题目:给一个不多于5位的正整数,要求:一.求它是几位数,二.逆序打印出各位数字. 程序设计: import java.util.Scanner; public class Ex24 { public static void main(String[] args) { Ex24 tn = new Ex24(); Scanner s = new Scanner(System.in); long a = s.nextLong(); if(a < 0 || a > 100000) { System.o

  • Java得到一个整数的绝对值,不使用任何判断和比较语句,包括API

    复制代码 代码如下: /** * Java得到一个整数的绝对值,不使用任何判断和比较语句,包括API. <br> * 1.不得使用任何API,如Math.abs()等.<br> * 2.不得使用判断语句,如if.for.while.switch.?:等.<br> * 3.不得使用比较语句,如:==. <=.>=.!=. <.>等. <br> * * @author JAVA世纪网(java2000.net, laozizhu.com)

随机推荐