lmj19851117 发表于 2011-9-27 22:22:24

求教VBS问题


如图,我现在想取最小值,为什么这样写,msgbox min 出来的总是 min的原值10000.我如果改一下max=0,n3>max,这样可以取出最大值。求教各位指点一下。

lyscser 发表于 2011-9-28 08:44:38

很简单,是字符串和整型比较的问题,谁在前面就把后面的强制转换为前面的变量类型
如果string和number比较,那么number就变成了string,至于谁大看长度
如果bumber和string比较,那么string是不是变成number我就不清楚了,如果你能确定你取出来的一定是数字,那么用Cint或者ABS强制转换一下再和10000去比才会有效
不知道我说的够不够清楚,请自己在编译器里面运行这两段代码就晓得了:
x = 10000
For i = 1 to 2
        a = "this is a string!"
        If         a < x Then
                msgbox "你觉得整型和字符串能比较?"
                x = a
        End If
        msgbox x
Next
x = 10000
For i = 1 to 2
        a = "this is a string!"
        If         x > a Then
                msgbox "你觉得整型和字符串能比较?"
                x = a
        End If
        msgbox x
Next
页: [1]
查看完整版本: 求教VBS问题