整型数字转汉字,如: [101] ->[一百零一]

jerry thinkphp 2015年11月18日 收藏
昨天发布了一段汉字转数字的代码,应该网友的要求,再写一个反转的算法,经过简单测试没发现问题,现在把代码分享出来,感兴趣的朋友可以来测试一下,呵呵,如果有更好的算法,也请拿出来分享下,最好是原创代码哦!
test2();

/**
 * 方法测试
 */
function test2() {
    echo '333030.22  =>  ' . IntToCn(333030.22) . '<hr />'; // 三十三万三千零三十
    echo '1111  => ' . IntToCn(1111.0001) . '<hr />'; // 一千一百一十一
    echo '101010101 => ' . IntToCn(101010101) . '<hr />'; // 一亿一百零一万零一百零一
}

/**
 * 数字转中文
 * @param Int $num 需要解析的数字
 * @param String $string 初始值
 * @return String
 * @author Anyon Zou <zoujingli@qq.com>
 * @date 2013-08-22 01:20
 */
function IntToCn($num, $string = array()) {
    if (!is_numeric($num)) {
        return $num;
    }
    $splits = array('100000000' => '亿', '10000' => '万');
    $chars = array('10000' => '万', '1000' => '千', '100' => '百', '10' => '十', '1' => '', '0' => '零');
    $ints = array('零', '一', '二', '三', '四', '五', '六', '七', '八', '九', '十');

    /*
     * 拆分整数与小数
     */
    $nums = explode('.', "{$num}");
    $num = $nums[0];
    // 处理小数
    $dou = array();
    if (!empty($nums[1])) {
        foreach (str_split("{$nums[1]}") as $n) {
            if (is_numeric($n)) {
                $dou[] = $ints[intval($n)];
            }
        }
    }
    unset($nums);

    foreach ($splits as $step => $split) {
        $floor = $step > 0 ? floor($num / intval($step)) : '0';
        if ($floor > 0) {
            $string[] = IntToCn($floor) . $split;
            $num = fmod($num, $step);
        }
    }
    $string2 = array();
    foreach ($chars as $step => $char) {
        $floor = $step > 0 ? floor($num / intval($step)) : '0';
        if ($floor > 0) {
            $string[] = $string2[] = $ints[$floor] . $char;
            $num = fmod($num, $step);
        } else if ((count($string2) > 0 || (count($string) > 0 && $step != '10000')) && $string2[count($string) - 1] != $ints[0] && $num > 0) {
            $string[] = $ints[0];
        }
    }
    if (!empty($dou)) {
        $string = array_merge($string, array('点'), $dou);
    }
    return join('', $string);
}
测试结果