作者:绿色风
分类:
时间:2022-08-17
浏览:171
楼主 amulee |
Q:如何用VBA返回多个区域最右列的列号? A:可以采用循环的方式遍历每个单元格找到最大的列号。请参考以下代码:
- Sub Test()
- Dim a As Range
- Dim R As Range
- Dim MaxC
- Set a = Range("a1:b1,a2:f2,a3:d3")
- For Each R In a
- If MaxC < R.Column Then MaxC = R.Column
- Next R
- MsgBox MaxC
- End Sub
|
2楼 amulee |
借用Kevin的思路,下面代码执行更快- Sub Test()
- Dim a As Range
- Dim R As Range
- Dim MaxC
- Set a = Range("a1:b1,a2:f2,a3:d3")
- For Each R In a
- If MaxC < R.Column Then MaxC = R.Column
- Next R
- MsgBox MaxC
- End Sub
|
3楼 wqfzqgk |
Q:如何用VBA返回多个区域最右列的列号? A:按单元格去循环是比较慢的,按下面的试一下- Sub test4()
- Dim arr()
- Set a = Range("a1:aaa1,a2:f2,a3:d3")
- i = 1
- For Each Row In a.Rows
- ReDim Preserve arr(1 To i)
- arr(i) = Val(Range(Row.Address).Columns.Count)
- i = i + 1
- Next
- MsgBox Application.WorksheetFunction.Max(arr)
- End Sub
- Sub test5()
- Dim arr()
- Dim reg As New RegExp
- Dim a As Range
- Set a = Range("a1,aaa2:fh2,a3:d3")
- b = a.Address(1, 0, xlR1C1)
- reg.Pattern = "\[\d*\]"
- reg.Global = True
- Set strr = reg.Execute(b)
- i = 1
- For Each sr In strr
- ReDim Preserve arr(1 To i)
- arr(i) = Val(Mid(sr, 2, Len(sr) - 2))
- i = i + 1
- Next
- MsgBox Application.WorksheetFunction.Max(arr) + 1
- End Sub
|
免责声明
有感于原ExcelTip.Net留存知识的价值及部分知识具有的时间限定性因素,
经与ExcelTip.Net站长Apolloh商议并征得其同意,
现将原属ExcelTip.Net的知识帖采集资料于本站点进行展示,
供有需要的人士查询使用,也慰缅曾经的论坛时代。
所示各个帖子的原作者如对版权有异议,
可与本人沟通提出,或于本站点留言,我们会尽快处理。
在此,感谢ExcelTip.Net站长Apolloh的支持,感谢本站点所有人**绿色风(QQ:79664738)**的支持与奉献,特此鸣谢!
------本人网名**KevinChengCW(QQ:1210618015)**原ExcelTip.Net总版主之一