php把字符串转换为大写_金额大小写顺序

php把字符串转换为大写_金额大小写顺序php金额大小写转换的方法:使用金额转换函数grees,代码为【$grees=array(“拾”,”佰”,”仟”,”万”,”拾”,”佰”,”仟”,”亿”);list($ns1,$ns2)=explode(“.”,$ns,2)】。php金额大小写转换的方法:早些年做CRM用到的一个金额转换函数,今天从旧项目中拿出来记录一下。金额转换的函数方法有很多,都很不错。不过这个是小崔刚工作的时候写的一个转换函…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

php金额大小写转换的方法:使用金额转换函数grees,代码为【$grees=array(“拾”,”佰”,”仟”,”万”,”拾”,”佰”,”仟”,”亿”);list($ns1,$ns2)=explode(“.”,$ns,2)】。

fa34b278c627b33aaac0546c0bc8a165.png

php金额大小写转换的方法:

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

废话不多说直接上代码:

function upper($ns) {

static $cnums=array(“零”,”壹”,”贰”,”叁”,”肆”,”伍”,”陆”,”柒”,”捌”,”玖”),

$cnyunits=array(“圆”,”角”,”分”),

$grees=array(“拾”,”佰”,”仟”,”万”,”拾”,”佰”,”仟”,”亿”);

list($ns1,$ns2)=explode(“.”,$ns,2);

$ns2=array_filter(array($ns2[1],$ns2[0]));

$ret=array_merge($ns2,array(implode(“”,calu(str_split($ns1),$grees)),””));

$ret=implode(“”,array_reverse(calu($ret,$cnyunits)));

return str_replace(array_keys($cnums),$cnums,$ret);

}

function calu($list,$units) {

$ul=count($units);

$xs=array();

foreach (array_reverse($list) as $x) {

$l=count($xs);

if ($x!=”0″ || !($l%4)) $n=($x==’0′?”:$x).($units[($l-1)%$ul]);

else $n=is_numeric($xs[0][0])?$x:”;

array_unshift($xs,$n);

}

return $xs;

}

echo upper(‘12121’);

?>

以上是基础转换代码,在这个基础上进行二次改造:<?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);想了解更多编程学习,敬请关注php培训栏目!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/185359.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • UVa 10763 – Foreign Exchange

    UVa 10763 – Foreign Exchange

  • 《跟老男孩学Linux运维:核心基础实战》勘误与反馈

    《跟老男孩学Linux运维:核心基础实战》勘误与反馈

  • jquery的validationEngine表单验证

    jquery的validationEngine表单验证本文主要引用https://www.cnblogs.com/aliger/p/3898216.html基于jquery的validationEngine表单验证插件,根据官网提示,该插件支持IE6-

  • 一笔画奇点偶点_一笔画图形奇点

    一笔画奇点偶点_一笔画图形奇点由一点引出的百线段为奇数个,则这个点为奇点。由一点引出的线段为偶数个,则这个点为偶点。一个图形判断能否被一笔画下来,关键是看奇点的个数:当奇点为0个或者2个时(不可能为一个,奇点都是成对出现),

  • 布隆过滤器工作原理_布隆过滤器的原理

    布隆过滤器工作原理_布隆过滤器的原理布隆过滤器(BloomFilter)是1970年由布隆提出的。它实际上是一个很长的二进制向量和一系列随机映射函数。布隆过滤器可以用于检索一个元素是否在一个集合中。它的优点是空间效率和查询时间都远远超过一般的算法,缺点是有一定的误识别率和删除困难。hash原理Hash(哈希,或者散列)函数在计算机领域,尤其是数据快速查找领域,加密领域用的极广。其作用是将一个大的数据集

  • 6.25科技新闻4

    6.25科技新闻4Lytro光场相机体验评测Lytro光场相机是一款可以先拍照,后对焦的相机。当时一出现就引起挺大的反响的,现在就随小编一起来体验一下这款光场相机吧! 关于光场相机的外观,小编不再累述了。各位可以到之前的《先拍后对焦LYTRO光场相机图赏》里面观看完整外观图。 首先我们来看看官方介绍:小编大概把图中的意思翻译了一下,翻译都在图上,看

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号