早些年做CRM用到的一个金额转换函数,今天从旧项目中拿出来记录一下。金额转换的函数方法有很多,都很不错。不过这个是小崔刚工作的时候写的一个转换函数,多少还是有点纪念意义。如有问题请朋友们指出,小崔及时修正。谢谢啦!

废话不多说直接上代码:

 <?php

 /**
 * 数字金额转换大写数字
 * $num 数字类型
 */

 function inttodaxie($num) {
     //判断$num是否数字
     if(!is_numeric($num)) return -1;
     $dint = array('零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖');
     $len = strlen($num);
     $dstr = '';
     for($i = 0; $i <= $len; $i++) {
         $key_ = substr($num, $i, 1);
         $dstr .= $dint[$key_];
     }
     return $dstr;
 }

 $result = inttodaxie(90011234);
 var_dump($result);
 echo '<br>';

以上是基础转换代码,在这个基础上进行二次改造:

 <?php

 /**
 * 转换大写金额
 * $num 数字类型
 */

 function inttod($num) {
     //判断$num是否存在
     if(!$num) return '零圆';
     //保留小数点后两位
     $num = round($num, 2);
     //将浮点转换为整数
     $tem_num = $num * 100;
     //判断数字长度
     $tem_num_len = strlen($tem_num);
     if($tem_num_len > 14) {
         return '数字太大了吧,有这么大的金钱吗';
     }

     //大写数字
     $dint = array('零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖');
     //大写金额单位
     $danwei = array('仟', '佰', '拾', '亿', '仟', '佰', '拾', '万', '仟', '佰', '拾', '圆');
     $danwei1 = array('角', '分');

     //空的变量用来保存转换字符串
     $daxie = '';

     //分割数字,区分圆角分
     list($left_num, $right_num) = explode('.', $num);

     //计算单位长度
     $danwei_len = count($danwei);
     //计算分割后的字符串长度
     $left_num_len = strlen($left_num);
     $right_num_len = strlen($right_num);

     //循环计算亿万元等
     for($i = 0; $i < $left_num_len; $i++) {
         //循环单个文字
         $key_ = substr($left_num, $i, 1);

         //判断数字不等于0或数字等于0与金额单位为亿、万、圆,就返回完整单位的字符串
         if($key_ !== '0' || ($key_ == '0' && ($danwei[$danwei_len - $left_num_len + $i] == '亿' || $danwei[$danwei_len - $left_num_len + $i] == '万' || $danwei[$danwei_len - $left_num_len + $i] == '圆'))) {
             $daxie = $daxie . $dint[$key_] . $danwei[$danwei_len - $left_num_len + $i];
         } else {
             //否则就不含单位
             $daxie = $daxie . $dint[$key_];
         }
     }

     //循环计算角分
     for($i = 0; $i < $right_num_len; $i++) {
         $key_ = substr($right_num, $i, 1);
         if($key_ > 0) {
             $daxie = $daxie . $dint[$key_] . $danwei1[$i];
         }
     }

     //计算转换后的长度
     $daxie_len = strlen($daxie);
     //设置文字切片从0开始,utf-8汉字占3个字符
     $j = 0;
     while($daxie_len > 0) {
         //每次切片两个汉字
         $str = substr($daxie, $j, 6);
         //判断切片后的文字不等于零万、零圆、零亿、零零
         if($str == '零万' || $str == '零圆' || $str == '零亿' || $str == '零零') {
             //重新切片
             $left = substr($daxie, 0, $j);
             $right = substr($daxie, $j + 3);
             $daxie = $left . $right;
         }
         $j += 3;
         $daxie_len -= 3;
     }

     return '人民币' . $daxie . '整';
 }

 $result = inttod(99090909090.19);
 var_dump($result);

运行结果:

源代码已上传GitHub:https://github.com/cuiyuanxin/php-demo/blob/master/capital.php

纯手打笔记,如有错误请评论提出,谢谢。

PHP数字金额转换大写金额的更多相关文章

  1. JavaScript将输入的数字金额转换成对应的中文大写金额

    // 将输入的数字金额转换成对应的中文大写金额 // idNumber输入的数字金额,idCHN输出的中文大写金额 function TransformNumberIntoCHN(idNumber, ...

  2. PHP算法--将数字金额转换成大写金额

    最近在看一些PHP算法题,遇到一个将数字金额转换成大写金额的小算法题,这里贴出自己的一个例子. 注:这个小算法适用于10万以内的金额. <?php //$num = 12345.67; func ...

  3. PHP 数字金额转换成中文大写金额的函数 数字转中文

    /** *数字金额转换成中文大写金额的函数 *String Int $num 要转换的小写数字或小写字符串 *return 大写字母 *小数位为两位 **/ function num_to_rmb($ ...

  4. C#小写数字金额转换成大写人民币金额的算法

    C#小写数字金额转换成大写人民币金额的算法 第一种方法: using System.Text.RegularExpressions;//首先引入命名空间 private string DaXie(st ...

  5. c#将输入的人民币数字金额转换成小写

    //// <summary> /// 人民币大小写金额转换 /// </summary> class RMBCapitalization { private const str ...

  6. irport报表,把数字金额转换成大写人民币金额

    1.编写oracle函数 CREATE OR REPLACE Function MoneyToChinese(Money In Number) Return Varchar2 Is strYuan ) ...

  7. java 数字金额转换中文金额

    public static String digitUppercase(double n){ String fraction[] = {"角", "分"}; S ...

  8. c#金额转换成中文大写金额

    2018-08-24 转别人 c#金额转换成中文大写金额 /// <summary> /// 金额转换成中文大写金额 /// </summary> /// <param ...

  9. 转一个财务方面常用到的数字金额转成汉字大写金额 php类

    系统里有牵扯到财务.合同等方面的处理时,常常需要把数字金额转成汉字大写金额(貌似这样正规),转一个转换的php class吧!<?php// 诸海加(ALPHA .z)// 2000-7-19 ...

随机推荐

  1. 转!! PreparedStatement是如何防止SQL注入的

    SQL注入最简单也是最常见的例子就是用户登陆这一模块,如果用户对SQL有一定的了解,同时系统并没有做防止SQL注入处理,用户可以在输入的时候加上'两个冒号作为特殊字符,这样的话会让计算机认为他输入的是 ...

  2. 同一服务器上多个版本的 sqlserver ,如何连接,改变某一实例的端口号

    1. SQL Server配置管理器,双击“TCP/IP” 2. TCP/IP设置 确定后重启SQL Server服务,打开SQL Server Management Studio,服务器名称输入12 ...

  3. python包下载地址

    https://pypi.python.org/pypi http://www.lfd.uci.edu/~gohlke/pythonlibs/ 当在线安装安装不了时,需要将安装包下载到本地,进行本地p ...

  4. java 线程数据同步

    java 线程数据同步 由买票实例 //java线程实例 //线程数据同步 //卖票问题 //避免重复卖票 //线程 class xc1 implements Runnable{ //定义为静态,可以 ...

  5. 利用nodejs+phantomjs+casperjs采集淘宝商品的价格

    因为一些业务需求需要采集淘宝店铺商品的销售价格,但是淘宝详情页面的价格显示是通过js动态调用显示的.所以就没法通过普通的获取页面html然后通过正则或者xpath的方式获取到想到的信息了. 所幸我们现 ...

  6. Objective-C编码规范:26个方面解决iOS开发问题

    介绍 我们制定Objective-C编码规范的原因是我们能够在我们的书,教程和初学者工具包的代码保持优雅和一致.即使我们有很多不同的作者来完成不同的书籍. 这里编码规范有可能与你看到的其他Object ...

  7. Linux宕机最安全的重启方法(你肯定不知道)

    Linux 内核虽然号称“不死族”,几乎不会崩溃或者死机,但是特殊情况下,还是有一定几率会宕机的.因为 Linux 广泛用于生产环境,所以每一次宕机都会引起相当大的损失.本文介绍在它死机至后,一种温柔 ...

  8. node07

    ---恢复内容开始--- 1.SQL基本查询语句 2.子句 1)WHERE 子句 WHERE key=val WHERE key>val WHERE key1>val1 AND key2& ...

  9. PyQt:左侧选项卡

    写在前面 正在用pyqt写我们比赛项目的客户端,针对左侧选项卡,写了一个简单的demo.记录一下. 环境 Python3.5.2 PyQt5 陈述 用的结构是左边一个QListWidget + 右边Q ...

  10. python 识别图片上的数字

    https://blog.csdn.net/qq_31446377/article/details/81708006 ython 3.6 版本 Pytesseract 图像验证码识别 环境: (1) ...