程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 一個阿拉伯數字轉中文數字的函數,阿拉伯中文

一個阿拉伯數字轉中文數字的函數,阿拉伯中文

編輯:關於PHP編程

一個阿拉伯數字轉中文數字的函數,阿拉伯中文


 

最近因需要,寫了個“阿拉伯數字轉中文數字的函數”。搜索了精華區只見到一個類似的。
感覺到我的算法不錯,所以貼出來共享一下如果要用於金額的轉換,對小數部分的處理要做一下修改
<?php
function ch_num($num,$mode=true) {
  $char = array("零","壹","貳","三","肆","伍","陸","柒","捌","玖");
  $dw = array("","拾","佰","仟","","萬","億","兆");
  $dec = "點";
  $retval = "";
  if($mode)
    preg_match_all("/^0*(\d*)\.?(\d*)/",$num, $ar);
  else
    preg_match_all("/(\d*)\.?(\d*)/",$num, $ar);
  if($ar[2][0] != "")
    $retval = $dec . ch_num($ar[2][0],false); //如果有小數,先遞歸處理小數
  if($ar[1][0] != "") {
    $str = strrev($ar[1][0]);
    for($i=0;$i<strlen($str);$i++) {
      $out[$i] = $char[$str[$i]];
      if($mode) {
        $out[$i] .= $str[$i] != "0"? $dw[$i%4] : "";
        if($str[$i]+$str[$i-1] == 0)
          $out[$i] = "";
        if($i%4 == 0)
          $out[$i] .= $dw[4+floor($i/4)];
      }
    }
    $retval = join("",array_reverse($out)) . $retval;
  }
  return $retval;
}
//echo ch_num("12345006789001.123");
//echo ch_num("880079.1234");
echo ch_num("300045.0123");
?>

       

詳細說明:http://php.662p.com/thread-364-1-1.html


Excel 2010怎把阿拉伯數字轉成中文大寫數字?(不要函數,有沒有工具直接轉換)

右鍵單元格,選擇"設置單元格格式",
"數字"標簽中左側選擇"特殊",右側選擇"中文大寫數字"
 

在excel中 怎將中文表示的數字轉換為阿拉伯數字??

沒有此方面的直接方法,得看你的數據有什麼樣的規則,才能決定用什麼函數幫忙。請舉個例子,詳細一些,如果不行,請傳文件過來分析。
 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved