文章が長くなり、スクロールが面倒なので、貼り直します。
下記のUKEに上手く代入されない理由を知りたいです。
IF文の中のCUTが上手く行ってないのはわかるんですが、理由がよくわからないです…。
B = Inputbox("式を入力してください。"&vbCr&_
vbCr&_
"※『=』は必要ありません。"&vbCr&_
"掛け算は『*』、割り算は『/』を使用してください。","数式の入力")
Y = Len(B)
i = 0
For i = 0 To Y - 1
A(i) = Mid(B,i+1,1)
If InStr(A(i),"+") Or InStr(A(i),"-") Or InStr(A(i),"*") Or InStr(A(i),"/") Then
For j = 0 To i - 1
x = CStr(x) + CStr(A(j))
Next
Exit For
End If
Next
S1 = StrReverse(B)
For KILL = 0 To Y - 1
A2(KILL) = Mid(S1,KILL+1,1)
If InStr(A2(KILL),"+") Or InStr(A2(KILL),"-") Or InStr(A2(KILL),"*") Or InStr(A2(KILL),"/") Then
For S2 = 0 To KILL - 1
AN1 = CStr(AN1) + CStr(A2(S2))
Next
Exit For
End If
Next
z = i + 1
S5 = KILL + 1
KO2 = StrReverse(S1)
AN2 = StrReverse(AN1)
'F1 = Mid(KO2,z+1,Y-Z-S5)
CUT = 0
For CUT = z To Y-Z-S5
A3(CUT) = Mid(KO2,z+1,Y-Z-S5)
If InStr(A3(CUT),"+") Or InStr(A3(CUT),"-") Or InStr(A3(CUT),"*") Or InStr(A3(CUT),"/") Then
CUT2 = CUT + 1
For T1 = z To CUT - 1
UKE = CStr(UKE) + CStr(A3(T1))
Next
Exit For
End If
Next
Y2 = Len(A3(CUT))
For T2 = CUT2 To Y2 - 1
UKE2 = CStr(UKE2) + CStr(A4(T2))
Next
If (A(i)) = "+" And (A2(KILL)) = "+" And (A3(CUT)) = "+" And (A4(T2)) = "+" Then
ans = CDbl(x) + CDbl(UKE) + CDbl(UKE2) + CDbl(AN2)
MsgBox "答えは"&ans&"です",,"答え"
MsgBox "++"
WScript.Quit
End If
MsgBox "x="&x
MsgBox "UKE="&UKE
MsgBox "UKE2="&UKE2
MsgBox "AN2="&AN2
MsgBox "F1="&F1
MsgBox "Y2="&Y2
MsgBox "A3(CUT)="&A3(CUT)
MsgBox "A3(T1)="&A3(T1)
MsgBox "CUT="&CUT
MsgBox "KILL="&KILL
MsgBox "i="&i
MsgBox "T1="&T1
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。