PHP人们币金额小写转大写类库

2024-09-05 19:18

本文主要是介绍PHP人们币金额小写转大写类库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MoneyConvertor 类:

MoneyConvertor.php 

<?php
/** * MoneyConvertor Library For PHP* 人民币大小写转换类* --------------------------------------------------- */
final class MoneyConvertor {//大写数字private $NUMBER_STR = array("零","壹","贰","叁","肆","伍","陆","柒","捌","玖");//整数位货币单位private $I_UNIT_STR = array("元","拾","佰","仟","万","拾","佰","仟","亿","拾","佰","仟");//小数位货币单位private $D_UNIT_STR = array("角","分","厘");//转换结果private $resultString = null;/*** 使用一个小写数字金额的字符串来转换resultString对象* ---------------------------------------------------* @param	$numberStr		将要转换的小写数字金额* @return 	$this->resultString*/public function convert($numberStr) {//处理小数位为0if(preg_match('/^[0-9]+\.[0]+$/',$numberStr))$numberStr = intval($numberStr);//补齐类似.5这样的无整数位数字if(substr($numberStr, 0, 1) == '.')number_format($numberStr);//如果带逗号分隔符的数字if(strpos($numberStr, ','))$numberStr = str_replace(",","",$numberStr);//如果数字达到万亿则提示数字过大,无法处理if ($numberStr>=1000000000000) return "数字太大,无法处理。抱歉!";//判断是否为数字if (!is_numeric($numberStr))return '不是有效的货币数值';//执行转换self::convertor($numberStr);//返回转换结果return $this->resultString;}/*** 执行转换* ---------------------------------------------------* @param	$numberStr		将要转换的小写数字金额* @return 	void*/private function convertor($numberStr){//分差整数与浮点位,整数和小数部分分开,分别进行转换$cutedNumber = explode('.', (string)$numberStr);//如果只有整数部分if (count($cutedNumber) == 1) {self::convertInteger($numberStr, TRUE);} else {self::convertInteger($cutedNumber[0]);self::convertDecimal($cutedNumber[1]);}//去除无用零字符self::removeZero();}/*** 对整数部分进行转换* ------------------------------------------------------------------* @param	$integer				将要转换的小写数字整数部分* @param	$without_fractional		是否原数不带浮点数,即在最后显示“整”** @return 	$this*/private function convertInteger($integer, $without_fractional = false) {$resultString = null;for ($i = 0; $i < strlen($integer); $i++) {$resultString .= $this->I_UNIT_STR[$i];$resultString .= $this->NUMBER_STR[substr(strrev($integer), $i, 1)];}//如果没有小数位$tidy = $without_fractional == false ? '' : '整';$this->resultString = self::str_reverse($resultString) . $tidy;return $this;}/*** 对小数点后三位部分进行转换* ------------------------------------------------------------------* @param	$integer				将要转换的小数点后三位部分* @return 	$this*/private function convertDecimal($decimal) {$resultString = null;for ($i = 0; $i < strlen($decimal); $i++) {$resultString .= $this->NUMBER_STR[substr($decimal, $i, 1)];$resultString .= $this->D_UNIT_STR[$i];if($i>1){/* echo "小数位过多!"; *///如果小数位过多则只显示小数点后三位$i = strlen($decimal);}}$this->resultString .= $resultString;return $this;}/*** 去掉多余的"零X"* ------------------------------------------------------------------* @return 	$this*/private function removeZero() {while (strpos($this->resultString, "零拾") || strpos($this->resultString, "零佰") || strpos($this->resultString, "零仟") || strpos($this->resultString, "零万") || strpos($this->resultString, "零亿") || strpos($this->resultString, "零角") || strpos($this->resultString, "零分") || strpos($this->resultString, "零厘") || strpos($this->resultString, "零零") || strpos($this->resultString, "亿万") || strpos($this->resultString, "零元")) {$this->resultString = str_replace("零拾", "零", $this->resultString);$this->resultString = str_replace("零佰", "零", $this->resultString);$this->resultString = str_replace("零仟", "零", $this->resultString);$this->resultString = str_replace("零万", "万", $this->resultString);$this->resultString = str_replace("零亿", "亿", $this->resultString);$this->resultString = str_replace("零角", "零", $this->resultString);$this->resultString = str_replace("零分", "零", $this->resultString);$this->resultString = str_replace("零厘", "零", $this->resultString);$this->resultString = str_replace("零零", "零", $this->resultString);$this->resultString = str_replace("亿万", "亿", $this->resultString);$this->resultString = str_replace("零元", "元", $this->resultString);}return $this;}/*** 中文UTF-8字符串反转* ------------------------------------------------------------------* @param 	$str	需要转换的UTF-8字符串* @return 	void*/function str_reverse($str) {//判断输入的是不是utf8类型的字符,否则退出if (!is_string($str) || !mb_check_encoding($str, 'UTF-8')) {return;}$array = array();//将字符串存入数组$l = mb_strlen($str, 'UTF-8');for ($i = 0; $i < $l; $i++) {$array[] = mb_substr($str, $i, 1, 'UTF-8');}//反转字符串krsort($array);//拼接字符串$string = implode($array);return $string;}
}
MoneyConvertor 类调用方法:

<?php
header("Content-type:text/html;charset=utf-8");
require "MoneyConvertor.php";
$moneyObj = new MoneyConvertor();
$output = '';
//value 表示要转换的小写数字,注意要对其小数位保留位数考虑
$value='222222222222.4';
$output = $moneyObj->convert($value);
echo $output;
?>


这篇关于PHP人们币金额小写转大写类库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1139833

相关文章

PHP执行php.exe -v命令报错的解决方案

《PHP执行php.exe-v命令报错的解决方案》:本文主要介绍PHP执行php.exe-v命令报错的解决方案,文中通过图文讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录执行phpandroid.exe -v命令报错解决方案执行php.exe -v命令报错-PHP War

Java基础回顾系列-第五天-高级编程之API类库

Java基础回顾系列-第五天-高级编程之API类库 Java基础类库StringBufferStringBuilderStringCharSequence接口AutoCloseable接口RuntimeSystemCleaner对象克隆 数字操作类Math数学计算类Random随机数生成类BigInteger/BigDecimal大数字操作类 日期操作类DateSimpleDateForma

PHP原理之内存管理中难懂的几个点

PHP的内存管理, 分为俩大部分, 第一部分是PHP自身的内存管理, 这部分主要的内容就是引用计数, 写时复制, 等等面向应用的层面的管理. 而第二部分就是今天我要介绍的, zend_alloc中描写的关于PHP自身的内存管理, 包括它是如何管理可用内存, 如何分配内存等. 另外, 为什么要写这个呢, 因为之前并没有任何资料来介绍PHP内存管理中使用的策略, 数据结构, 或者算法. 而在我们

php中json_decode()和json_encode()

1.json_decode() json_decode (PHP 5 >= 5.2.0, PECL json >= 1.2.0) json_decode — 对 JSON 格式的字符串进行编码 说明 mixed json_decode ( string $json [, bool $assoc ] ) 接受一个 JSON 格式的字符串并且把它转换为 PHP 变量 参数 json

如何将文件夹里的PHP代码放到一个文件里

find ./dir -name "*.php" -exec 'cat' {} \; > dir.out

PHP抓取网站图片脚本

方法一: <?phpheader("Content-type:image/jpeg"); class download_image{function read_url($str) { $file=fopen($str,"r");$result = ''; while(!feof($file)) { $result.=fgets($file,9999); } fclose($file); re

PHP防止SQL注入详解及防范

SQL 注入是PHP应用中最常见的漏洞之一。事实上令人惊奇的是,开发者要同时犯两个错误才会引发一个SQL注入漏洞。 一个是没有对输入的数据进行过滤(过滤输入),还有一个是没有对发送到数据库的数据进行转义(转义输出)。这两个重要的步骤缺一不可,需要同时加以特别关注以减少程序错误。 对于攻击者来说,进行SQL注入攻击需要思考和试验,对数据库方案进行有根有据的推理非常有必要(当然假设攻击者看不到你的

PHP防止SQL注入的方法(2)

如果用户输入的是直接插入到一个SQL语句中的查询,应用程序会很容易受到SQL注入,例如下面的例子: $unsafe_variable = $_POST['user_input'];mysql_query("INSERT INTO table (column) VALUES ('" . $unsafe_variable . "')"); 这是因为用户可以输入类似VALUE”); DROP TA

PHP防止SQL注入的方法(1)

(1)mysql_real_escape_string – 转义 SQL 语句中使用的字符串中的特殊字符,并考虑到连接的当前字符集 使用方法如下: $sql = "select count(*) as ctr from users where username ='".mysql_real_escape_string($username)."' and password='". mysql_r

Linux系统安装php开发环境

Linux系统centos6.5 PHP5.6 MySQL5.6 Nginx1.7 yum安装依赖库 yum install -y make cmake gcc gcc-c++ autoconf automake libpng-devel libjpeg-devel zlib libxml2-devel ncurses-devel bison \libtool-ltdl-devel li