就是下面这个程序,查1470369258最后三位的位置总是返回0,s(I)是数组,公用的,高手给看一下呀,谢谢
Sub 判断201()
For I = 1 To 3
If InStr("1470369258", s(I)) <= 3 Then
R(I) = 1
R1(I) = R2(I) + 1
ElseIf InStr("1470369258", s(I)) > 3 <= 7 Then
R(I) = 0
R0(I) = R0(I) + 1
ElseIf InStr("1470369258", s(I)) > 7 Then
R(I) = 2
R2(I) = R1(I) + 1
End If
Next I
End Sub
这种问题哟。。。baidu一下不就行了么
而且VB也会提示你语法的你何必条件反射一样看都不看呢
Instr(Start,String1,String2[,.....])
Start表示从String1的第几个字符开始查找匹配,最小值为1
如
Instr(1,"abc","c")=3
至于上面的InStr("1470369258", s(I))这种用法纯属胡闹
要是不是胡闹呢?
你测试过麽?还是以前没有用过?o(∩_∩)o
他错在
InStr("1470369258", s(I)) > 3 <= 7
Sub 判断201()
For i = 1 To 3
If InStr("1470369258", s(i)) <= 3 Then
R(i) = 1
R1(i) = R2(i) + 1
ElseIf InStr("1470369258", s(i)) <= 7 Then
R(i) = 0
R0(i) = R0(i) + 1
ElseIf InStr("1470369258", s(i)) > 7 Then
R(i) = 2
R2(i) = R1(i) + 1
End If
Next i
End Sub
要是不是胡闹呢?
你测试过麽?还是以前没有用过?o(∩_∩)o
他错在
InStr("1470369258", s(I)) > 3 <= 7
Sub 判断201()
For i = 1 To 3
If InStr("1470369258", s(i)) <= 3 Then
R(i) = 1
R1(i) = R2(i) + 1
ElseIf InStr("1470369258", s(i)) <= 7 Then
R(i) = 0
R0(i) = R0(i) + 1
ElseIf InStr("1470369258", s(i)) > 7 Then
R(i) = 2
R2(i) = R1(i) + 1
End If
Next i
End Sub
啊……还真没测试过 纯属凭经验说话……
我尽快测试
InStr 函数
返回 Variant (Long),指定一字符串在另一字符串中最先出现的位置。
语法
InStr([start, ]string1, string2[, compare])
InStr 函数的语法具有下面的参数:
部分 说明
start 可选参数。为数值表达式,设置每次搜索的起点。如果省略,将从第一个字符的位置开始。如果 start 包含 Null,将发生错误。如果指定了 compare 参数,则一定要有 start 参数。
string1 必要参数。接受搜索的字符串表达式。
string2 必要参数。被搜索的字符串表达式。
Compare 可选参数。指定字符串比较。如果 compare 是 Null,将发生错误。如果省略 compare,Option Compare 的设置将决定比较的类型。
设置
compare 参数设置为:
常数 值 描述
vbUseCompareOption -1 使用Option Compare 语句设置执行一个比较。
vbBinaryCompare 0 执行一个二进制比较。
vbTextCompare 1 执行一个按照原文的比较。
vbDatabaseCompare 2 仅适用于Microsoft Access,执行一个基于数据库中信息的比较。
返回值
如果 InStr返回
string1 为零长度 0
string1 为 Null Null
string2 为零长度 Start
string2 为 Null Null
string2 找不到 0
在 string1 中找到string2 找到的位置
start > string2 0
说明
InStrB 函数作用于包含在字符串中的字节数据。所以 InStrB 返回的是字节位置,而不是字符位置。