前言
敲完工作代码,遇到个群里有人问有没有好的123456789转一亿二千三百四十五万六千七百八十九的方法。正好拿来放松下。
先去网上找了有没有相关的资料,找到一个比较好的思路:
var n = 123456789
var zh = ['零', '一', '二', '三', '四', '五', '六', '七', '八', '九'];
[...String(n)].map(item => zh[parseInt(item, 10)]).join(''); // 就能获得一二三四五六七八九
正文代码
// 不支持012100012这种错误格式判断
function arabicToChinese(n, type = 'zh') {
n = typeof(n) == 'string'? parseInt(n, 10): n;
let zhArr, zhUnit;
// 增加一个繁简判断
if (type = 'zh') {
zhArr = ['零', '一', '二', '三', '四', '五', '六', '七', '八', '九'];
zhUnit = ['', '十', '百', '千', '万', '亿', '万亿', '亿亿'];
} else if(type = 'zhtw') {
zhArr = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖'];
zhUnit = ['', '拾', '佰', '仟', '万', '亿','万亿', '亿亿'];
}
// result是输出结果,unitPos是循环中当前排到的位置,wan、yi、wanyi都是单位是否添加的标志
let result = '', unitPos = 0, wan = false, yi = false, wanyi = false;
while(n>0) {
// %为取模,n除以10最后的余数,此法为获取n的最后一位,因为后面会对n进行n=Math.floor(n/10)的位数缩减
// 所以此法循环可有效获取n的每一位数值
let y = n % 10;
if (y === 0) {
// 阿拉伯数字12356789转对应中文
// 如果是零的话,就不会涉及到单位
result = zhArr[y] + result;
} else {
// 阿拉伯数字12356789转对应中文
// 非零的话,会涉及到单位
// 0-4位需取十百千,5-8位只需取一次单位万,9-12位只需取一次单位亿
if(unitPos>=0 && unitPos <4){
result = zhArr[y] + zhUnit[unitPos] + result;
} else if (unitPos>=4 && unitPos <8) {
if (!wan) {
wan = true;
result = zhArr[y] + zhUnit[unitPos-4] + zhUnit[4] + result ;
} else {
result = zhArr[y] + zhUnit[unitPos-4] + result;
}
} else if (unitPos >= 8 && unitPos <12) {
if (!yi) {
yi = true;
result = zhArr[y] + zhUnit[unitPos-8] + zhUnit[5] + result;
} else {
result = zhArr[y] + zhUnit[unitPos-8] + result;
}
} else if (unitPos >= 12 && unitPos < 16) {
if (!wanyi) {
wanyi = true;
result = zhArr[y] + zhUnit[unitPos-12] + zhUnit[6] + result;
} else {
result = zhArr[y] + zhUnit[unitPos-12] + result;
}
}
}
unitPos++;
n = Math.floor(n / 10);
}
// 处理多个零的情况,变成一个零
result = result.replace(/\零{2,}/g, '零');
// 处理最后一位为零的情况
if (result.endsWith('零')) {
result = result.substr(0, result.length-1)
}
return result;
}