国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 編程設計 > 正文

如何實現人民幣的大寫轉換?

2020-06-19 13:51:56
字體:
來源:轉載
供稿:網友

第一個辦法,這個程序可以進行萬億以下的貨幣金額轉換(夠用的了吧),其中漢字與數字均按一位計:

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 = "
"
'                    nZero = 0
                End If
            ElseIf I = J - 2 Then
                Ch2 = "
"
            ElseIf I = J Then
                Ch2 = "
"
            Else
                Ch2 = ""
            End If
            nZero = 0
        End If

        AtoC = AtoC & Ch1 & Ch2
    Next I

        AtoC = Replace(AtoC, "零元", "")
        AtoC = Replace(AtoC, "
零萬", "")
        AtoC = Replace(AtoC, "
零億", "")
        AtoC = Replace(AtoC, "
零整", "")
       '
以上將多余的零去掉

End Function

 

第二個辦法:照下面寫就成了!

<%
dim str(9)
str(0)="
"
str(1)="
"
str(2)="
"
str(3)="
"
str(4)="
"
str(5)="
"
str(6)="
"
str(7)="
"
str(8)="
"
str(9)="
"
aa=Request.form("source")
hh=formatnumber(aa,2,-1)
aa=replace(hh,".","")
aa=replace(aa,",","")
for i=1 to len(aa)
    s=mid(aa,i,1)
  mynum=str(s)
  select case(len(aa)+1-i)
    case 1: k= mynum&"
"
    case 2: k= mynum&"
"
    case 3: k= mynum&"
"
    case 4: k= mynum&"
"
    case 5: k= mynum&"
"
    case 6: k= mynum&"
"
    case 7: k= mynum&"
"
    case 8: k= mynum&"
"
    case 9: k= mynum&"
"
    case 10: k= mynum&"
"
  end select
    m=m&k
next
%>

<html>
<head>
<title>
精彩春風之數字大小寫轉換</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<!--
Elseif(s=".") then
    n=m
    i=i+2
    for j=i to len(aa)
      s=mid(aa,i,1)
        mynum=str(s)
      select case(len(aa)+1-i)
      case 1: p= mynum&"
"
      case 2: p= mynum&"
"
      end select
      m=m&p
    next
-->

<body>
<form method="post"  name="forma">
  <input type="text" name="source" value="<%=hh%>">
  =
  <input type="text" name="result" value="<%=m%>" size="40">

<input type="submit" name="Submit" value="
開始轉換" >
</form>
</body></html>

 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 万荣县| 加查县| 阳山县| 宁城县| 长垣县| 葫芦岛市| 忻城县| 江华| 饶阳县| 余江县| 旺苍县| 且末县| 湘西| 同仁县| 安多县| 无棣县| 鹰潭市| 昆山市| 荔浦县| 北宁市| 万全县| 白水县| 怀化市| 高青县| 亳州市| 溧水县| 固阳县| 四平市| 弥渡县| 宁河县| 三门峡市| 西乌| 乐亭县| 昌宁县| 紫金县| 遂昌县| 沙洋县| 海原县| 板桥市| 广饶县| 广饶县|