Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 9462|回复: 6

[已解决]VBA中,TRUE代表为-1吗?

[复制链接]
发表于 2010-3-10 21:33 | 显示全部楼层 |阅读模式

sub AA

MsgBox (1 = 1) * 10

end sub

上述代码运行后为什么显示-10

最佳答案
2010-3-10 21:39

真没注意过,一直以为是1,查了帮助,转换成其他数据类型时是-1

帮助原文:

当转换 Boolean 值为其他的数据类型时,False 成为 0,而 True 成为 -1。

发表于 2010-3-10 21:39 | 显示全部楼层    本楼为最佳答案   

真没注意过,一直以为是1,查了帮助,转换成其他数据类型时是-1

帮助原文:

当转换 Boolean 值为其他的数据类型时,False 成为 0,而 True 成为 -1。

回复

使用道具 举报

 楼主| 发表于 2010-3-10 21:43 | 显示全部楼层
回复

使用道具 举报

发表于 2010-3-10 21:45 | 显示全部楼层

逻辑值转化为数值:true=-1,false=0

数值转化为逻辑值:非0=true,0=false

回复

使用道具 举报

发表于 2010-3-10 21:50 | 显示全部楼层


Sub a()
    Dim x
    
    x = 3
    MsgBox CBool(x) '返回 True
    MsgBox CInt(CBool(x)) '返回-1
End Sub

真是个大发现呀,学习了!我去看了下帮助:

 

 

Boolean 数据类型
请参阅     示例     特性

Boolean 变量存储为 16 位(2 个字节)的数值形式,但只能是 True 或是 False。Boolean 变量的值显示为 True 或 False(在使用 Print 的时候),或者 #TRUE# 或 #FALSE#(在使用 Write # 的时候)。使用关键字 True 与 False 可将 Boolean 变量赋值为这两个状态中的一个。

当转换其他的数值类型为 Boolean 值时,0 会转成 False,而其他的值则变成 True。当转换 Boolean 值为其他的数据类型时,False 成为 0,而 True 成为 -1。

回复

使用道具 举报

发表于 2010-3-10 21:59 | 显示全部楼层

就是,所以才有:当要根据单元格有没有内容来执行某段代码时,就写成了 if len(单元格.value) then,这比其他写法速度要快点点(不多次读单元格哈,要将单元格.value先读入变量,len(变量))
[此贴子已经被作者于2010-3-10 22:34:00编辑过]
回复

使用道具 举报

发表于 2010-3-10 22:13 | 显示全部楼层

是这样的啦

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-5-17 04:24 , Processed in 0.260622 second(s), 7 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表