一、如何将数字转换成人民币大写?
有时候,为了方便读取数字,我们通常会将数字转换成人民币大写的形式,下面主要通过以下2种方法来进行转换。
第一种,用自定义格式的方式进行转换
选中需要转换成人民币大写的数字---Ctrl+1---特殊----人民币大写----确定即可
第二种:用text函数进行转换
选中已经转换成人民币大写的数字----ctrl+1----自定义----类型----将其代码复制出来
在E2单元格输入公式:
=TEXT(D2,"[DBNum2][$RMB]G/通用格式;[红色][DBNum2][$RMB]G/通用格式")
二、 如何将数字转换成财务大写金额?
在填制报销单的时候,我们经常需要对报销的金额转换成财务大写金额的形式,如何转换呢?
只需在E2单元格输入公式:
=TEXT(INT(D2),"[dbnum2]")&TEXT(RIGHT(D2*100,2),"元[dbnum2]0角0分")
具体的步骤为:
1.先用INT函数将D2单元格中的整数部分提取出来, 再用text函数将其转换成大写的形式
2.将D2单元格中的数字乘以100,用right函数提取右边的2位数,再用text函数将其转换成大写的元0角0分的形式
3.最后用&连接符将其连接起来即可
一、效果图
当小写文本框输入完毕,失去焦点时转换为人民币大写,并显示到大写文本框。
二、js代码
<script type="text/javascript"> /** 数字金额大写转换(可以处理整数,小数,负数) */ function smalltoBIG(n) { var fraction = ['角', '分']; var digit = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖']; var unit = [ ['元', '万', '亿'], ['', '拾', '佰', '仟'] ]; var head = n < 0? '负': ''; n = Math.abs(n); var s = ''; for (var i = 0; i < fraction.length; i++) { s += (digit[Math.floor(n * 10 * Math.pow(10, i)) % 10] + fraction[i]).replace(/零./, ''); } s = s || '整'; n = Math.floor(n); for (var i = 0; i < unit[0].length && n > 0; i++) { var p = ''; for (var j = 0; j < unit[1].length && n > 0; j++) { p = digit[n % 10] + unit[1][j] + p; n = Math.floor(n / 10); } s = p.replace(/(零.)*零$/, '').replace(/^$/, '零') + unit[0][i] + s; } return head + s.replace(/(零.)*零元/, '元').replace(/(零.)+/g, '零').replace(/^整$/, '零元整'); } function convertRMB(){ var srmb=Number(document.getElementById("smallrmb").value); console.log(srmb); document.getElementById("bigrmb").value = smalltoBIG(srmb);} </script>
三、html代码
小写:<input id="smallrmb" type="text" onBlur="convertRMB()"><br>大写:<input id="bigrmb" type="text">