Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/excel/28.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/vba/17.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Excel 选择“全部”时vba target.count=1错误_Excel_Vba_Target_Selectionchanged - Fatal编程技术网

Excel 选择“全部”时vba target.count=1错误

Excel 选择“全部”时vba target.count=1错误,excel,vba,target,selectionchanged,Excel,Vba,Target,Selectionchanged,我有一个工作表,其中包含的代码会根据选择的单元格触发某些VBA代码。(单元格具有按钮的功能)。 由于用户可以选择包含多个单元格的范围,因此限制该问题的方法(当单元格包含在所选范围内时不会触发vba代码,但它不是唯一的单元格)是使用target.count 当用户选择多个单元格(包括触发vba的单元格)时,这项工作确实很好,但我想知道,当用户使用CTRL-A选择所有单元格时,为什么会出现错误 这是工作表后面的代码 Sub Worksheet_SelectionChange(ByVal Target

我有一个工作表,其中包含的代码会根据选择的单元格触发某些VBA代码。(单元格具有按钮的功能)。 由于用户可以选择包含多个单元格的范围,因此限制该问题的方法(当单元格包含在所选范围内时不会触发vba代码,但它不是唯一的单元格)是使用target.count 当用户选择多个单元格(包括触发vba的单元格)时,这项工作确实很好,但我想知道,当用户使用CTRL-A选择所有单元格时,为什么会出现错误

这是工作表后面的代码

Sub Worksheet_SelectionChange(ByVal Target As Range)
If Target.Count = 1 Then
     run some code
如果我用contrl-A选择整个工作表,则会出现错误ocurr

运行时错误6 溢出

更奇怪的是。该工作表包含一个表(listobject)。如果在表中执行ctrl-a,则会选中整个表,并且不会发生错误。 如果在表外执行ctrl-A,则会选中整个工作表并发生错误


对这种行为有什么解释

tldr您试图在Range.Count属性中检索太大的数字

写入Range.Count属性是为了返回解析为Range对象中单个单元格总数的长整数


返回一个长值,该值表示集合中的对象数

您将收到运行时错误6:溢出,因为XLSX工作表上的单个单元格总数为1048576行×16384(A到XFD)列。这将解析为17179869184个超过有符号长整数的最大alllowed值的单个单元格



有符号长整数可以保留的最大值为2147483647或&H7FFF,FFFF16。

tldr您试图在Range.Count属性中检索太大的数字

写入Range.Count属性是为了返回解析为Range对象中单个单元格总数的长整数


返回一个长值,该值表示集合中的对象数

您将收到运行时错误6:溢出,因为XLSX工作表上的单个单元格总数为1048576行×16384(A到XFD)列。这将解析为17179869184个超过有符号长整数的最大alllowed值的单个单元格



有符号长整数可以保留的最大值为2147483647或&H7FFF,FFFF16。

Target.CountLarge
属性替换
Target.Count


Ref:

将您的
目标.Count
替换为
目标.CountLarge
属性


Ref:

最有可能是因为在选定单元格的特定数量上使用计数错误(计数是一种长数据类型)。使用CountLarge就像这里解释的那样:很可能是因为在选定单元格的特定数量上使用count错误(count是一种长数据类型)。使用CountLarge,如此处所述: