首页 > 解决方案 > 复制粘贴循环 vba - 覆盖当前单元格

问题描述

如果创建可以从一张纸复制并粘贴到另一张纸的 vba,我正在这个过程中。

这是循环:

j = Archive.Range("A12", Archive.Range("A12").End(xlToRight).Columns.Count --> count of sheet 2 

(参考表 1:如果第 15 行中的任何一列是 1,那么它将复制到存档)

For i = k to 2 Step -1

If Reference.Cells(15, i). Value = 1 Then Reference.Columns(i).Copy
Archive.Cells(1, 1 + j).PasteSpecial
End If
Next i

宏正在工作,但循环的问题是它只复制并粘贴到下一个可用单元格上,如果单元格 15 中的另一条记录等于 1,则不会继续到下一个单元格。我希望它连续复制粘贴数据到下一个可用列。

标签: excelvbaexcel-2016

解决方案


您需要j在循环内更新。

例如,如果j最初等于 15,那么1 + j对于循环的每次迭代都将等于 16。1 + j永远不会改变 的值j

改为尝试:

If Reference.Cells(15, i). Value = 1 Then 
    j = j + 1  ' update j
    Reference.Columns(i).Copy
    Archive.Cells(1, j).PasteSpecial
End If

推荐阅读