字符串:货币金额大写格式

原创 2012年03月27日 21:19:26
package based.string;

import java.text.DecimalFormat;
import java.util.Scanner;

public class ConvertMoney {
	public static final String STR_UNIT[] = { "", "拾", "佰", "仟", "万", "拾",
			"佰", "仟", "亿", "拾", "佰", "仟" };
	public static final String STR_NUMBER[] = { "零", "壹", "贰", "叁", "肆", "伍",
			"陆", "柒", "捌", "玖" };
	public static final String STR_UNIT1[] = { "毛", "分", "厘" };

	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		System.out.println("请输入一个金额");
		String convert = convert(scan.nextDouble());
		System.out.println(convert);
	}

	public static String convert(double d) {
		DecimalFormat df = new DecimalFormat("#0.###");
		String strNum = df.format(d);
		if (strNum.indexOf(".") != -1) {
			String num = strNum.substring(0, strNum.indexOf("."));
			if (num.length() > 12) {
				System.out.println("数字太大,不能完成转换");
			}
		}
		String point = "";
		if(strNum.indexOf(".")!=-1){
			point="元";
		}else{
			point="元整";
		}
		String result = getInteger(strNum) + point + getDecimal(strNum);
		if(result.startsWith("元整")){
			 result="零元";
		 }
		 if(result.startsWith("元")){
		 result=result.substring(1,result.length());
		 }
		 return result;
	}

	public static String getInteger(String num) {
		if (num.indexOf(".") != -1) {
			num = num.substring(0, num.indexOf("."));
		}
		num = new StringBuffer(num).reverse().toString();
		StringBuffer temp = new StringBuffer();
		for (int i = 0; i < num.length(); i++) {
			temp.append(STR_UNIT[i]);
			temp.append(STR_NUMBER[num.charAt(i) - 48]);
		}
		num = temp.reverse().toString();
		num = num.replaceAll("零元", "元");
		num = num.replaceAll("零拾", "");
		num = num.replaceAll("零佰", "");
		num = num.replaceAll("零仟", "");
		num = num.replaceAll("零万", "万");
		num = num.replaceAll("零亿", "亿");
		num = num.replaceAll("亿万", "亿");
		if (num.lastIndexOf("零") == num.length() - 1) {
			num = num.substring(0, num.length() - 1);
		}
		return num;
	}

	public static String getDecimal(String num) {
		if (num.indexOf(".") != -1) {
			num = num.substring(num.indexOf(".") + 1, num.length());
		} else
			return "";
		StringBuffer temp = new StringBuffer();
		for (int i = 0; i < num.length(); i++) {
			temp.append(STR_NUMBER[num.charAt(i) - 48]);
			temp.append(STR_UNIT1[i]);
			}
		num=temp.toString();
		num = num.replaceAll("零毛", "");
		num = num.replaceAll("零分", "");
		num = num.replaceAll("零厘", "");
		return num;
	}
}

Java 货币金额大写格式

/*  * 1.将数字格式化,如果有小数,留3位到厘;  * 2、分别将整数和小数部分转换为大写方式,并插入单位;  * 3、组合整数和小数部分;  */ public class Conv...

Delphi货币类型转中文大写金额

在Delphi中,为了实现货币数值运算中的严格精度要求,内部把货币类型数据当作一个放大10000倍的64位整数来处理。这样根据64位整数的范围,可以得出货币类型Currency的范围是 [-92233...
  • tht2009
  • tht2009
  • 2017年06月15日 15:03
  • 376

货币金额大写转换

将小写阿拉伯数字转换为大写汉字广泛应用于银行各种书写情景 代码如下:import java.text.DecimalFormat; import java.util.Scanner; public ...

浮点数转换为大写货币金额

/** * 浮点数转换为大写货币金额 * * @author Bobby * */ public class ConvertFloatNumToRMBFormat { private ...

Java 中使用POI设置EXCEL单元格格式为文本、小数、百分比、货币、日期、科学计数法和中文大写、单元格边框等

第一种:日期格式 cell.setCellValue(new Date(2008,5,5)); //set date format ...

POI设置EXCEL单元格格式为文本、小数、百分比、货币、日期、科学计数法和中文大写

转:http://blog.csdn.net/loveany121/article/details/7938367 再读本篇文章之前,请先看我的前一篇文章,前一篇文章中有重点讲到POI设置EXC...
  • foart
  • foart
  • 2012年11月17日 11:00
  • 1941

NPOI设置格式文本、小数、百分比、货币、日期、科学计数法和中文大写

HSSFWorkbook demoWorkBook = new HSSFWorkbook(); HSSFSheet demoSheet = demoWorkBook.cr...

POI设置EXCEL单元格格式为文本、小数、百分比、货币、日期、科学计数法和中文大写

文章出处:点击打开链接 http://javacrazyer.iteye.com/blog/894850 再读本篇文章之前,请先看我的前一篇文章,前一篇文章中有重点讲到POI设置EX...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:字符串:货币金额大写格式
举报原因:
原因补充:

(最多只允许输入30个字)