您现在的位置是:网站首页> 编程资料编程资料
如何实现人民币的大写转换?_编程10000问_
                     2023-05-25
                186人已围观
                
                2023-05-25
                186人已围观
            
简介 如何实现人民币的大写转换?_编程10000问_
第一个办法,这个程序可以进行万亿以下的货币金额转换(够用的了吧),其中汉字与数字均按一位计:
Function AtoC(a As Currency) As String
     ' 定义两个字符串,A的值最多是两位小数. 
    Dim String1 As String  
' 如下定义.
    Dim String2 As String  
' 如下定义.
    Dim String3 As String  
' 从原A值中取出的值.
    Dim I As Integer       
' 循环变量.
Dim J As Integer
' A的值乘以100的字符串长度.
    Dim Ch1 As String      
' 数字的汉语读法.
    Dim Ch2 As String      
' 数字位的汉字读法.
    Dim nZero As Integer    
' 用来计算连续的非零数是几个.
    String1 = "零壹贰叁肆伍陆柒捌玖"
    String2 = "万仟佰拾亿仟佰拾万仟佰拾元角分"
    'MsgBox CStr(a * 100)
    If InStr(1, CStr(a * 100), ".") <> 0 Then
        err.Raise 5000, , "该函数( AtoC() )只转换两位小数以内的数值!"
    End If
    J = Len(CStr(a * 100))
    String2 = Right(String2, J)        
' 取出对应位数的StrING2的值.
    For I = 1 To J
        String3 = Mid(a * 100, I, 1)    
' 取出需转换的某一位的值.
        If String3 <> "0" Then
            Ch1 = Mid(String1, Val(String3) + 1, 1)
            Ch2 = Mid(String2, I, 1)
            nZero = nZero + 1          
' 表示本位不为零.
        Else
            If nZero <> 0 Or I = J - 9 Or I = J - 5 Or I = J - 1 Then
                If Right(AtoC, 1) = "零" Then AtoC = Left(AtoC, Len(AtoC) - 1)
                Ch1 = "零"
            Else
                Ch1 = ""
            End If
                                   
If I = J - 10 Then
' 如果转换的数值需要扩大,则要改动以下表达式 I 的值.
                Ch2 = "亿"
            ElseIf I = J - 6 Then
                If nZero <> 0 Then
                    Ch2 = "万
 
                                
                                                         
                                
                                                         
                                
                                                         
 
    