JavaScript实现阿拉伯数字和中文数字互相转换


Posted in Javascript onJune 12, 2016

阿拉伯数字转中文数字
中文数字的特点:

  • 每个计数数字都跟着一个权位,权位有:十、百、千、万、亿。
  • 以“万”为小节,对应一个节权位,万以下没有节权位。
  • 每个小节内部以“十百千”为权位独立计数。
  • “十百千”不能连续出现,而“万”和“亿”作为节权位时可以和其他权位连用,如:“二十亿”。

中文数字对“零”的使用要满足以下三条规则:

  • 以10000为小节,小节的结尾即使是0,也不使用零。
  • 小节内两个非0数字之间要使用“零”。
  • 当小节的“千”位是0时(即:1~999),只要不是首小节,都要补“零”。

算法设计的一些说明:

  • 对“零”的第三个规则,把检测放在循环的最前面并默认为false,可以自然的丢弃最高小节的加零判断。
  • 单个数字转换用数组实现,var chnNumChar = ["零","一","二","三","四","五","六","七","八","九"];
  • 节权位同样用数组实现,var chnUnitSection = ["","万","亿","万亿","亿亿"];
  • 节内权位同样用数组实现,var chnUnitChar = ["","十","百","千"];

节内转换算法:

function SectionToChinese(section){
  var strIns = '', chnStr = '';
  var unitPos = 0;
  var zero = true;
  while(section > 0){
    var v = section % 10;
    if(v === 0){
      if(!zero){
        zero = true;
        chnStr = chnNumChar[v] + chnStr;
      }
    }else{
      zero = false;
      strIns = chnNumChar[v];
      strIns += chnUnitChar[unitPos];
      chnStr = strIns + chnStr;
    }
    unitPos++;
    section = Math.floor(section / 10);
  }
  return chnStr;
}

转换算法主函数:

function NumberToChinese(num){
  var unitPos = 0;
  var strIns = '', chnStr = '';
  var needZero = false;

  if(num === 0){
    return chnNumChar[0];
  }

  while(num > 0){
    var section = num % 10000;
    if(needZero){
      chnStr = chnNumChar[0] + chnStr;
    }
    strIns = SectionToChinese(section);
    strIns += (section !== 0) ? chnUnitSection[unitPos] : chnUnitSection[0];
    chnStr = strIns + chnStr;
    needZero = (section < 1000) && (section > 0);
    num = Math.floor(num / 10000);
    unitPos++;
  }

  return chnStr;
}

中文数字转阿拉伯数字
设计思想:

  • 将中文数学转换成阿拉伯数字。
  • 将中文权位转换成10的位数。
  • 对每个权位依次转换成位数并求和。
  • 零直接忽略即可。

中文数字转换成阿拉伯数字用如下对象实现:

var chnNumChar = {
  零:0,
  一:1,
  二:2,
  三:3,
  四:4,
  五:5,
  六:6,
  七:7,
  八:8,
  九:9
};

中文权位转换成10的位数及节权标志用如下对象实现:

var chnNameValue = {
  十:{value:10, secUnit:false},
  百:{value:100, secUnit:false},
  千:{value:1000, secUnit:false},
  万:{value:10000, secUnit:true},
  亿:{value:100000000, secUnit:true}
}

转换算法如下:

function ChineseToNumber(chnStr){
  var rtn = 0;
  var section = 0;
  var number = 0;
  var secUnit = false;
  var str = chnStr.split('');

  for(var i = 0; i < str.length; i++){
    var num = chnNumChar[str[i]];
    if(typeof num !== 'undefined'){
      number = num;
      if(i === str.length - 1){
        section += number;
      }
    }else{
      var unit = chnNameValue[str[i]].value;
      secUnit = chnNameValue[str[i]].secUnit;
      if(secUnit){
        section = (section + number) * unit;
        rtn += section;
        section = 0;
      }else{
        section += (number * unit);
      }
      number = 0;
    }
  }
  return rtn + section;
}
Javascript 相关文章推荐
推荐:极酷右键菜单
Nov 29 Javascript
JS实现点击链接取消跳转效果的方法
Jan 24 Javascript
在浏览器中实现图片粘贴的jQuery插件-- pasteimg使用指南
Dec 29 Javascript
充分发挥Node.js程序性能的一些方法介绍
Jun 23 Javascript
js仿拉勾网首页穿墙广告效果
Mar 08 Javascript
使用JavaScript实现alert的实例代码
Jul 06 Javascript
详解Vue学习笔记进阶篇之列表过渡及其他
Jul 17 Javascript
基于jQuery实现Ajax验证用户名是否可用实例
Mar 25 jQuery
详解Angular5 路由传参的3种方法
Apr 28 Javascript
详解基于vue-cli3.0如何构建功能完善的前端架子
Oct 09 Javascript
使用form-create动态生成vue自定义组件和嵌套表单组件
Jan 18 Javascript
微信小程序页面滚动到指定位置代码实例
Sep 07 Javascript
深入解析JavaScript中的arguments对象
Jun 12 #Javascript
基于css3新属性transform及原生js实现鼠标拖动3d立方体旋转
Jun 12 #Javascript
JS弹出窗口插件zDialog简单用法示例
Jun 12 #Javascript
jQuery实现拖拽页面元素并将其保存到cookie的方法
Jun 12 #Javascript
仅一个form表单 js实现注册信息依次填写提交功能
Jun 12 #Javascript
JS+HTML5手机开发之滚动和惯性缓动实现方法分析
Jun 12 #Javascript
浅谈如何实现easyui的datebox格式化
Jun 12 #Javascript
You might like
PHP编码规范之注释和文件结构说明
2010/07/09 PHP
php模拟post上传图片实现代码
2016/06/24 PHP
添加JavaScript重载函数的辅助方法2
2010/07/04 Javascript
js查错流程归纳
2012/05/04 Javascript
js innerHTML 改变div内容的方法
2013/08/03 Javascript
深入理解JavaScript是如何实现继承的
2013/12/12 Javascript
查找Oracle高消耗语句的方法
2014/03/22 Javascript
jquery获取复选框被选中的值
2014/04/10 Javascript
关于img的href和src取变量及赋值的方法
2014/04/28 Javascript
JavaScript实现的购物车效果可以运用在好多地方
2014/05/09 Javascript
jquery实现在页面加载完毕后获取图片高度或宽度
2014/06/16 Javascript
jQuery实现form表单基于ajax无刷新提交方法详解
2015/12/08 Javascript
学习使用AngularJS文件上传控件
2016/02/16 Javascript
JS全局变量和局部变量最新解析
2016/06/24 Javascript
详解Node.js项目APM监控之New Relic
2017/05/12 Javascript
基于Vue过渡状态实例讲解
2017/09/14 Javascript
Vue.js实现的购物车功能详解
2019/01/27 Javascript
layui table 表格上添加日期控件的两种方法
2019/09/28 Javascript
vue 实现v-for循环回来的数据动态绑定id
2019/11/07 Javascript
《javascript设计模式》学习笔记五:Javascript面向对象程序设计工厂模式实例分析
2020/04/08 Javascript
JS array数组检测方式解析
2020/05/19 Javascript
[01:49]一目了然!DOTA2DotA快捷操作对比第二弹
2014/05/16 DOTA
简单介绍Python的轻便web框架Bottle
2015/04/08 Python
Python字符串转换成浮点数函数分享
2015/07/24 Python
python实现微信自动回复功能
2018/04/11 Python
numpy.linspace 生成等差数组的方法
2018/07/02 Python
Python使用修饰器进行异常日志记录操作示例
2019/03/19 Python
使用python os模块复制文件到指定文件夹的方法
2019/08/22 Python
解决python -m pip install --upgrade pip 升级不成功问题
2020/03/05 Python
css3动画事件—webkitAnimationEnd与计时器time事件
2013/01/31 HTML / CSS
关于h5中的fetch方法解读(小结)
2017/11/15 HTML / CSS
娇韵诗加拿大官网:Clarins加拿大
2017/11/20 全球购物
介绍一下Cookie和Session及他们之间的区别
2012/11/20 面试题
班主任经验交流会主持词
2014/04/01 职场文书
2014年小学美术工作总结
2014/12/20 职场文书
2015年感恩父亲节活动策划方案
2015/05/05 职场文书