js怎么把数字金额转换成中文大写金额
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js怎么把数字金额转换成中文大写金额相关的知识,希望对你有一定的参考价值。
参考技术A http://link.fobshanghai.com/rmb.htm,参考网址。<script>
function convertCurrency(currencyDigits)
// Constants:
var MAXIMUM_NUMBER = 99999999999.99;
// Predefine the radix characters and currency symbols for output:
var CN_ZERO = "零";
var CN_ONE = "壹";
var CN_TWO = "贰";
var CN_THREE = "叁";
var CN_FOUR = "肆";
var CN_FIVE = "伍";
var CN_SIX = "陆";
var CN_SEVEN = "柒";
var CN_EIGHT = "捌";
var CN_NINE = "玖";
var CN_TEN = "拾";
var CN_HUNDRED = "佰";
var CN_THOUSAND = "仟";
var CN_TEN_THOUSAND = "万";
var CN_HUNDRED_MILLION = "亿";
var CN_SYMBOL = "人民币";
var CN_DOLLAR = "元";
var CN_TEN_CENT = "角";
var CN_CENT = "分";
var CN_INTEGER = "整";
// Variables:
var integral; // Represent integral part of digit number.
var decimal; // Represent decimal part of digit number.
var outputCharacters; // The output result.
var parts;
var digits, radices, bigRadices, decimals;
var zeroCount;
var i, p, d;
var quotient, modulus;
// Validate input string:
currencyDigits = currencyDigits.toString();
if (currencyDigits == "")
alert("请输入小写金额!");
return "";
if (currencyDigits.match(/[^,.\d]/) != null)
alert("小写金额含有无效字符!");
return "";
if ((currencyDigits).match(/^((\d1,3(,\d3)*(.((\d3,)*\d1,3))?)|(\d+(.\d+)?))$/) == null)
alert("小写金额的格式不正确!");
return "";
// Normalize the format of input digits:
currencyDigits = currencyDigits.replace(/,/g, ""); // Remove comma delimiters.
currencyDigits = currencyDigits.replace(/^0+/, ""); // Trim zeros at the beginning.
// Assert the number is not greater than the maximum number.
if (Number(currencyDigits) > MAXIMUM_NUMBER)
alert("金额过大,应小于1000亿元!");
return "";
// Process the coversion from currency digits to characters:
// Separate integral and decimal parts before processing coversion:
parts = currencyDigits.split(".");
if (parts.length > 1)
integral = parts[0];
decimal = parts[1];
// Cut down redundant decimal digits that are after the second.
decimal = decimal.substr(0, 2);
else
integral = parts[0];
decimal = "";
// Prepare the characters corresponding to the digits:
digits = new Array(CN_ZERO, CN_ONE, CN_TWO, CN_THREE, CN_FOUR, CN_FIVE, CN_SIX, CN_SEVEN, CN_EIGHT, CN_NINE);
radices = new Array("", CN_TEN, CN_HUNDRED, CN_THOUSAND);
bigRadices = new Array("", CN_TEN_THOUSAND, CN_HUNDRED_MILLION);
decimals = new Array(CN_TEN_CENT, CN_CENT);
// Start processing:
outputCharacters = "";
// Process integral part if it is larger than 0:
if (Number(integral) > 0)
zeroCount = 0;
for (i = 0; i < integral.length; i++)
p = integral.length - i - 1;
d = integral.substr(i, 1);
quotient = p / 4;
modulus = p % 4;
if (d == "0")
zeroCount++;
else
if (zeroCount > 0)
outputCharacters += digits[0];
zeroCount = 0;
outputCharacters += digits[Number(d)] + radices[modulus];
if (modulus == 0 && zeroCount < 4)
outputCharacters += bigRadices[quotient];
zeroCount = 0;
outputCharacters += CN_DOLLAR;
// Process decimal part if there is:
if (decimal != "")
for (i = 0; i < decimal.length; i++)
d = decimal.substr(i, 1);
if (d != "0")
outputCharacters += digits[Number(d)] + decimals[i];
// Confirm and return the final output string:
if (outputCharacters == "")
outputCharacters = CN_ZERO + CN_DOLLAR;
if (decimal == "")
outputCharacters += CN_INTEGER;
outputCharacters = CN_SYMBOL + outputCharacters;
return outputCharacters;
</script>
如何自动把数字转换成大写的金钱?
参考技术AExcel 根据数字金额自动生成大写金额的操作方法:
一、首先点击选中需要同步大写金额的单元格,按Ctrl+!打开单元格格式窗口。
二、打开单元格格式窗口后,点击左侧的“特殊”,右边使用“中文大写数字”,点击“确定”。
三、然后在大写金额单元格中输入“=A2”,点击回车。
四、这时即可自动生成和A2单元格数值相同的大写数字。
五、当A2单元格内的数值被修改后,B2单元格内的大写数值也会自动同步更改。
以上是关于js怎么把数字金额转换成中文大写金额的主要内容,如果未能解决你的问题,请参考以下文章