【发布时间】:2015-10-21 15:44:42
【问题描述】:
我正在尝试执行以下操作:我想将不同的区域(以黄色标记)存储在一个字符串中。第一个黄色区域是 F7:G8,第二个是 I7:J8,依此类推,字符串变为:“F7:G8,I7:J8,L7:M8,F10:G11,I10:J11, L10:M11”。
所以在这个例子中,我在右边有三个区域,在下面有两个。向右和向下的区域数量可能会有所不同,因此我想编写一个代码,我只需要指定向右和向下的区域数量。请注意,第一个区域始终是 F7:G8,因此我可以将其用作参考。现在,在下一个区域之前跳过多少列可能会有所不同,并且在下一个区域之前跳过多少行可能会有所不同。所以我需要考虑到这一点。
我有以下 VBA 代码:
Sub test()
'
' test Makro
'
'
Dim i As Integer, j As Integer
k = 2 'areas downwards'
l = 3 'areas rightwards'
Dim area As String
Let area = "F7:G8" 'first area, always the same'
Dim Upper_letter As String
Let Upper_letter = "F"
Dim Upper_nr As String
Let Upper_nr = "7"
Dim Lower_letter As String
Let Lower_letter = "G"
Dim Lower_nr As String
Let Lower_nr = "8"
For i = 1 To k
For j = 1 To l
area = area & "," & Upper_letter & Upper_nr ":" & Lower_letter & Lower_number
'How do I add 3 letters to both Upper_letter and Lower_letter after each iteration of j?'
Next j
upper_nr = upper_nr + 3 'after each iteration of i, add 3'
lower_nr = lower_nr + 3 'after each iteration of i, add 3'
Next i
End Sub
所以我看不到如何在最里面的循环中添加字母。
【问题讨论】:
-
使用单元格(行,列)。地址(假,假)。列可以是数字。
-
您可能想研究创建命名范围。你可以做单独的,或者它也会允许不连续的范围。
-
感谢两位的评论。 @ScottCraner 我以前从未听说过,但我会尝试调查一下。