gpt4 book ai didi

vba - 在 VBA 中使用单元格值引用来确定范围

转载 作者:行者123 更新时间:2023-12-04 22:08:15 25 4
gpt4 key购买 nike

我知道这是一个非常基本的问题,但我仍在努力培养我的 VBA 技能。我处于一个困境中,我已经将收到的各种报告制作成一个映射系统,这些报告被放置在一个已编译的工作簿中。这些报告具有完全不同的格式等。我有一个复制/粘贴宏,可以复制列并将它们放在已编译工作簿上的正确位置。

但是,我遇到了很多重复/空行搞砸了我的宏的情况。我使用了两个 VBA 函数来解决这个问题,一个是“如果引用列为空白则删除行”:

Sub DeleteBlankARows()
With Application
.Calculation = xlCalculationManual
.ScreenUpdating = False
Dim r As Long
For r = Cells(Rows.Count, 6).End(xlUp).Row To 1 Step -1
If Cells(r, 6) = "" Then Rows(r).Delete
Next r
.Calculation = xlCalculationAutomatic
.ScreenUpdating = True
End With End Sub

这将删除 F 列中的单元格为空的行

我还使用复制/粘贴宏:
Sub CopyUntilBlank()
Dim last_row As Integer
last_row = Range("f1").End(xlDown).Row

Dim rng As Range
Set rng = Range("d2:d" & last_row)

For Each cell In rng.Cells
cell.Activate
If ActiveCell.Value = "" Then
ActiveCell.Value = ActiveCell.Offset(-1, 0).Value
End If
Next cell End Sub

这将复制并粘贴 D 列中的空白行,直到您点击一个非空白单元格,然后重新执行此操作,直到 F 列中的值范围。

这些宏对我来说效果很好,但是因为我有多个这样的工作表,所以我想创建一个使范围动态的单元格引用。例如:在 DeleteBlankRows 宏中,我希望根据 sheet1 中的单元格值确定 Cells(r,6) 中的列引用 - 例如,如果工作表 1 上的单元格 A1 中的值为 2,它将改变列对“2”的引用(B 列)。

我希望复制/粘贴宏也能发生同样的情况。我很确定这只是对 A1.Value 的一些引用,但我不知道如何正确编写这样的东西。

感谢您的支持,在社区的所有支持下,我已经走了很长一段路。

最佳答案

使用您的第一个子的示例:

Sub DeleteBlankARows(colIndex as Long)
Dim colIndex as long
colIndex = Sheet1.Range("a1").value
With Application
.Calculation = xlCalculationManual
.ScreenUpdating = False
Dim r As Long
For r = Cells(Rows.Count, colIndex).End(xlUp).Row To 1 Step -1
If Cells(r, colIndex) = "" Then Rows(r).Delete
Next r
.Calculation = xlCalculationAutomatic
.ScreenUpdating = True
End With
End Sub

从您的问题中不清楚第二个子中的哪一列需要是动态的(或两者都需要?)

编辑 尝试这个:
Sub CopyUntilBlank()
Dim last_row As Long, col1 as Long, col2 as Long
Dim rng as Range

col1 = Sheet1.Range("a2").value
col2 = Sheet1.Range("a3").value

last_row = Cells(1, col1).End(xlDown).Row
'This next line is better if there's any chance
' of blanks in this column
'last_row = Cells(Rows.Count, col1).End(xlUp).Row

With ActiveSheet
Set rng = .Range(.Cells(2, col2), .Cells(last_row, col2))
End With

For Each cell In rng.Cells
If cell.Value = "" Then
cell.Value = cell.Offset(-1, 0).Value
End If
Next cell

End Sub

关于vba - 在 VBA 中使用单元格值引用来确定范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15885118/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com