excel - 如何遍历名称集合并返回对象的大小?
问题描述
我正在尝试遍历 Names 集合,并且每个符合特定大小(列)要求的名称都会调整大小(在不同的子中调用)。
当我尝试将返回的名称传递给 Range 时,出现以下错误。
“运行时错误'1004':对象'_Global'的方法'Range'失败。
Sub colCounts()
Dim wb as Workbook
Dim nm as Name
Dim rng as Range
Set wb = ActiveWorkbook
For Each nm in wb.Names
debug.print nm.Name ' verify loop returning as expected
Set rng = Range(nm.Name) 'this line throws the error when added
debug.print nm.Name & " " & rng.Columns.Count
Next nm
End Sub
我还尝试先将名称传递给字符串:
Dim str as String
.....
str = nm.Name
Set rng = Range(str)
解决方案
Sub colCounts()
Dim wb As Workbook
Dim nm As Name
Dim rng As range
Set wb = ActiveWorkbook
For Each nm In wb.Names
Set rng = ThisWorkbook.Names(nm.Name).RefersToRange
Debug.Print nm.Name & " " & rng.Columns.Count
Next nm
End Sub
推荐阅读
- java - Jenkins kubernetes 插件:提供的端口:50000 不可访问
- git - git - 重置提交次数
- javafx - 在 ArcGIS 中将给定的几何图形转换为 PointCollection
- c# - Photon Bolt:跨网络的网络 ID 不一致
- r - 如何在ggplot2中按多个变量分组
- .net - Ignite 服务器停止响应许多“无法向远程节点发送消息”
- c# - 在 Xml 反序列化期间,矩阵返回 null
- docker - docker中的nextcloudpi:无法使用已安装的外部存储
- angular - “AngularFireAuth”类型上不存在属性“auth”
- android - Camera2 SENSOR_INFO_SENSITIVITY_RANGE 特定分辨率/模式的值