zoukankan      html  css  js  c++  java
  • 数字转换成中文汉字

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

    <html xmlns="http://www.w3.org/1999/xhtml">

    <head>

        <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />

        <title>无标题文档</title>

    </head>

    <body>

    </body>

    </html>

    <script type="text/javascript">

    var _change = {

     ary0:["零", "一", "二", "三", "四", "五", "六", "七", "八", "九"],  

    ary1:["", "十", "百", "千"],

     ary2:["", "万", "亿", "兆"],

      init:function (name) {  

         this.name = name;

      },

     strrev:function () {  

          var ary = Array();

          for (var i = this.name.length; i >= 0; i--) {    

                      ary.push(this.name.charAt(i));  

             }     

         return ary.join("");  //倒转字符串。

    },

     pri_ary:function () {

      var $this = this;

      var ary = this.strrev();  

     var zero = "";   var newary = "";  

     var i4 = -1;

      for (var i = 0; i < ary.length; i++) {

       if (i % 4 == 0) { //首先判断万级单位,每隔四个字符就让万级单位数组索引号递增      

             i4++;

            newary = this.ary2[i4] + newary; //将万级单位存入该字符的读法中去,它肯定是放在当前字符读法的末尾,所以首先将它叠加入$r中,      

            zero = ""; //在万级单位位置的“0”肯定是不用的读的,所以设置零的读法为空    

     }    //关于0的处理与判断。      

      if (ary.charAt(i) == '0') { //如果读出的字符是“0”,执行如下判断这个“0”是否读作“零”     

             switch (i % 4) {

          case 0:

          break;       //如果位置索引能被4整除,表示它所处位置是万级单位位置,这个位置的0的读法在前面就已经设置好了,所以这里直接跳过

          case 1:      

         case 2:      

        case 3:      

       if (ary[i - 1] != '0') {

              zero = "零"      

           }       ;       //如果不被4整除,那么都执行这段判断代码:如果它的下一位数字(针对当前字符串来说是上一个字符,因为之前执行了反转)也是0,那么跳过,否则读作“零”       break;          

      }  

       newary = zero + newary;   

      zero = '';        

     }else { //如果不是“0”    

         newary = this.ary0[parseInt(ary.charAt(i))] + this.ary1[i % 4] + newary;     //就将该当字符转换成数值型,并作为数组ary0的索引号,以得到与之对应的中文读法,其后再跟上它的的一级单位(空、十、百还是千)最后再加上前面已存入的读法内容。   

      }     

    }      

    if (newary.indexOf("零") == 0) {

       newary = newary.substr(0)    

       }//处理前面的0    

        return newary;

     }

    }

    //创建class类

    function change() {     this.init.apply(this, arguments); }

    change.prototype = _change

    //创建实例

    var index = '682';

    var k = new change(index);

    var pri_ary = k.pri_ary();

    //alert(k.pri_ary())

    var textNum;

    if(index<20&&index>=10){  

       textNum = pri_ary.substr(1,2);

      }else{  

       textNum = pri_ary;

    }

    alert(textNum)

    </script>

  • 相关阅读:
    python基础知识0-5(单双向队列)
    python基础知识0-4
    python函数篇0-1
    面试题17:合并两个排序的链表
    面试题16:反转链表
    面试题15:链表中倒数第k个结点
    面试题14:调整数组顺序使奇数位于偶数前面
    面试题13:在O(1)时间删除链表结点
    面试题12:打印1到最大的n位数
    面试题11:数值的整数次方
  • 原文地址:https://www.cnblogs.com/dearxinli/p/3030455.html
Copyright © 2011-2022 走看看