金额小写变大写 VB版本

 '
'/ <summary>
'/ 金额小写变大写
'/ </summary>
'/ <param name="smallnum"></param>
'/ <returns></returns>
Public Shared Function gMoney(smallnum As Decimal) As String
   Dim cmoney, cnumber, cnum, cnum_end, cmon, cno, snum, sno As String
   Dim snum_len, sint_len, cbegin, zflag, i As Integer
   If smallnum > 1000000000000.ToUInt32() Or smallnum < - 99999999999.ToUInt32() Or smallnum = 0 Then
      Return ""
   End If
   cmoney = "仟佰拾亿仟佰拾万仟佰拾元角分" ' 大写人民币单位字符串
   cnumber = "壹贰叁肆伍陆柒捌玖" ' 大写数字字符串
   cnum = "" ' 转换后的大写数字字符串
   cnum_end = "" ' 转换后的大写数字字符串的最后一位
   cmon = "" ' 取大写人民币单位字符串中的某一位
   cno = "" ' 取大写数字字符串中的某一位
  
  
   snum = Round(smallnum, 2).ToString("############.00") ' 小写数字字符串
   snum_len = snum.Length ' 小写数字字符串的长度
   sint_len = snum_len - 2 ' 小写数字整数部份字符串的长度
   sno = "" ' 小写数字字符串中的某个数字字符
   cbegin = 15 - snum_len ' 大写人民币单位中的汉字位置
   zflag = 1 ' 小写数字字符是否为0(0=0)的判断标志
   i = 0 ' 小写数字字符串中数字字符的位置
   If snum_len > 15 Then
      Return ""
   End If
   For i = 0 To snum_len - 1
      If i = sint_len - 1 Then
         GoTo ContinueFor1
      End If
     
      cmon = cmoney.Substring(cbegin, 1)
      cbegin = cbegin + 1
      sno = snum.Substring(i, 1)
      If sno = "-" Then
         cnum = cnum + "负"
         GoTo ContinueFor1
      Else
         If sno = "0" Then
            cnum_end = cnum.Substring(cnum.Length - 2, 1)
            If cbegin = 4 Or(cbegin = 8 Or cnum_end.IndexOf("亿") >= 0 Or cbegin = 12) Then
               cnum = cnum + cmon
               If cnumber.IndexOf(cnum_end) >= 0 Then
                  zflag = 1
               Else
                  zflag = 0
               End If
            Else
               zflag = 0
            End If
            GoTo ContinueFor1
         Else
            If sno <> "0" And zflag = 0 Then
               cnum = cnum + "零"
               zflag = 1
            End If
         End If
      End If
      cno = cnumber.Substring(System.Convert.ToInt32(sno) - 1, 1)
      cnum = cnum + cno + cmon
   ContinueFor1:
   Next i
   If snum.Substring(snum.Length - 2, 1) = "0" Then
      Return cnum + "整"
   Else
      Return cnum
   End If
End Function 'gMoney
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值