将数字转换为大写人民币值

public static String convertRMB(double value) {
if (value == 0) {
return "零元";
}
char[] hunit = {‘拾‘, ‘佰‘, ‘仟‘}; //段内位置表示
char[] vunit = {‘万‘, ‘亿‘}; //段名表示
char[] digit = {‘零‘, ‘壹‘, ‘贰‘, ‘叁‘, ‘肆‘, ‘伍‘, ‘陆‘, ‘柒‘, ‘捌‘, ‘玖‘}; //数字表示
long midVal = (long) (((value+0.000001) * 1000) / 10); //转化成整形
String valStr = String.valueOf(midVal); //转化成字符串
//确保字符串长度大于等于2
if (valStr.length() == 1) {
valStr = "0" + valStr;
}
String head = valStr.substring(0, valStr.length() - 2);//取整数部分
String rail = valStr.substring(valStr.length() - 2);//取小数部分
String prefix = ""; //整数部分转化的结果
String suffix = ""; //小数部分转化的结果
//处理小数点后面的数
if (rail.equals("00")) { //如果小数部分为0
suffix = "整";
} else {
suffix = digit[rail.charAt(0) - ‘0‘] + "角" + digit[rail.charAt(1) - ‘0‘] + "分";//否则把角分转化出来
}
//处理小数点前面的数
char[] chDig = head.toCharArray(); //把整数部分转化成字符数组
char zero = ‘0‘; //标志‘0‘表示出现过0
byte zeroSerNum = 0; //连续出现0的次数
for (int i = 0; i < chDig.length; i++) {//循环处理每个数字
int idx = (chDig.length - i - 1) % 4;//取段内位置
int vidx = (chDig.length - i - 1) / 4;//取段位置
if (chDig[i] == ‘0‘) {//如果当前字符是0
zeroSerNum++; //连续0次数递增
if (idx == 0 && vidx > 0 && zeroSerNum < 4) {//标志
prefix += vunit[vidx - 1];
zero = ‘0‘;
} else if (zero == ‘0‘) {
zero = digit[0];
}
continue;
}
zeroSerNum = 0;//连续0次数清零
if (zero != ‘0‘) {//如果标志不为0,则加上,例如万,亿什么的
prefix += zero;
zero = ‘0‘;
}
prefix += digit[chDig[i] - ‘0‘];//转化该数字表示
if (idx > 0) prefix += hunit[idx - 1];
if (idx == 0 && vidx > 0) {
prefix += vunit[vidx - 1];//段结束位置应该加上段名如万,亿
}
}
if (prefix.length() > 0)
prefix += ‘元‘;//如果整数部分存在,则有元的字样
return prefix + suffix;//返回正确表示
}

//测试

@Test
public void test(){
System.out.println(convertRMB(25));//输出 贰拾伍元整
}

时间: 2024-11-07 17:14:06

将数字转换为大写人民币值的相关文章

将金额数字转换为大写汉字的js函数

1 //将金额数字转换为大写汉字的函数 2 function convertCurrency(money) { 3 //汉字的数字 4 var cnNums = new Array('零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖'); 5 //基本单位 6 var cnIntRadice = new Array('', '拾', '佰', '仟'); 7 //对应整数部分扩展单位 8 var cnIntUnits = new Array('', '

Java中金额数字转换为大写数字

注:该代码来自于别人,我引入进来并修改了里面的几个bug.现在写进我的博客里,以便于日后查看,和为其它博友们提供方便 修改bug地方:1.金额为0时,不加整.以前是零元整,现在是零元    2.修改"分", "角", "元","万", "亿","兆"位不会出现零 package com.zbx.bs.common.util;import java.math.BigDecimal; /**

在Excel中将数字转换为大写

123.09 = 壹佰贰拾叁元零玖分 =SUBSTITUTE(SUBSTITUTE(IF(G10<0,"負","")&TEXT(TRUNC(ABS(ROUND(G10,2))),"[DBNum2]")&"元"&IF(ISERR(FIND(".",ROUND(G10,2))),"",TEXT(RIGHT(TRUNC(ROUND(G10,2)*10)),&quo

小写数字转大写

--小写数字转大写,只是单纯的将数字转换为大写了,还要加单位 create or replace function chinese(number1 number) return varchar2 is Result varchar2(30):=' '; v_chinese varchar2(25):='零壹贰叁肆伍陆柒捌玖'; v_char varchar2(10); begin for i in 1..length(number1) loop select substr(v_chinese,s

将阿拉伯数字转换为大写

<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <meta http-equiv="X-UA-Compatible"

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

/** * 浮点数转换为大写货币金额 * * @author Bobby * */ public class ConvertFloatNumToRMBFormat { private static String[] upperCaseArray = { "零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌&

c# 财务报表数字转大写的方法

/// <summary>/// 数字转大写/// </summary>/// <param name="Num">数字</param>/// <returns></returns> public static string CmycurD(decimal num) { string str1 = "零壹贰叁肆伍陆柒捌玖"; //0-9所对应的汉字 string str2 = "万仟佰

Oracle 小写金额转换为大写

在开发EBS的合同报表打印的时候需要将小写金额转换为大写. 如下是本人自己写的转换函数. 主要思路:先获取小数点位置,在区分整数与小数点处理,根据位数和数字组合读取金额. 最后再处理特殊显示部分. /******************************************************************* *  FUNCTION get_big_amount 数字金额转换为大写 *  p_amount 输入数据金额 *  返回大写金额,位数 :千亿----厘 ****

JS将数字转换为中文

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>JS将数字转换为中文</title> </head> <body> <script> // 定义转换函数 function transform(tranvalue){ try{ var i=1; var dw2 = new Array("",