最大处理数字位为十亿,转换规则为,千位有零必须读,其他为没零可以不读
比如说一千万零一百元,一千万一千元,一千万一万一千元
思路大概是:先处理共通的,后处理个别特殊的(千位的零;多个零写作一个)
r = n % 4
// r 0 1 2 3
// 位 千 个 十 百
然后根据长度判断 确定 亿,万,x;加到末尾
把“零”以及后一个删除,但是其后一个是“个”字,就不删除“个”,
以及千位若是“零”则不删除;另外,千位以下多个“零”只保留一个“零”(百位和十位可以为“零”)
把“个”替换为对应的“亿,万”
下面实现参考和转自不知来源处: ```javascript function chineseNumber(num) { //汉字的数字 var cnNums = new Array('零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖');
//基本数位单位
var cnIntRadice = new Array('', '拾', '佰', '仟');
//整数部分扩展数位单位
var cnIntUnits = new Array('', '万', '亿', '兆');
//最大处理的数字
var maxNum = 9999999999;
//输出的中文数字符串
var chineseStr = '';
// 如果输入为空,返回空
if (num == ''){
return '';
}
if (parseInt(num) > maxNum) {
//超出最大处理数字
return '超出最大处理数字';
}
// 如果输入为0,返回零
if (num == '0'){
chineseStr = cnNums[0];
return chineseStr;
}
var zeroCount = 0; // 遇零计数
var intLen = integerNum.length; // 数字符串总长度
// 开始打印中文数字
for (var i = 0; i < intLen; i++) {
var n = integerNum.substr(i,1); //取字符
var p = intLen - i - 1; //求数位级位置
//例如:12345678, i=2位,下标[2](字符为3)-对应'拾'万数级, 8-2-1=5 模%4佘1,取cnIntRadice[m]数组m=1位下标是'拾'
var q = p / 4; //定-0空、1万、2亿、3兆 4种扩展数位
var m = p % 4; //定-0空、1拾、2佰、3千 4种基本数位
if (n == '0'){ //遇零计数
zeroCount++;
} else {
if (zeroCount > 0 && m != 3){ //非千位有零存在加零字符,遇千跳过不加零
chineseStr += cnNums[0];
}
//加入零字符后,计数归零
zeroCount = 0;
//加入字符与位级'空拾佰千'
chineseStr += cnNums[parseInt(n)] + cnIntRadice[m];
}
// 在空位级,加不加万、亿、兆
if (m == 0 && zeroCount < 4){
chineseStr += cnIntUnits[q];
}
}
return chineseStr;
}
var integerNum = window.prompt('请输入低于10位的数字',123456789);
var chineseText = chineseNumber(integerNum);
console.log('你输入了:' + integerNum);
console.log('中文大写:' + chineseText);
document.write('你输入了:' + integerNum);
document.write('<br>中文大写:' + chineseText);