Se pretendermos copiar dados de uma folha para outra, de modo sequencial e partindo do princípio de que esses dados não se encontram sempre, na sua origem, nas mesmas células, mas mantendo-se na mesma ordem por coluna, como no exemplo:
Folha1 (1º momento):
data:image/s3,"s3://crabby-images/88d0f/88d0fa1a11e6d84204086b133f180922d9e8c439" alt=""
Folha2 (1º momento):
data:image/s3,"s3://crabby-images/1ddbf/1ddbfa4525860e7dd7c8bc2016554cdaee976536" alt=""
Folha1 (2º momento):
data:image/s3,"s3://crabby-images/71b40/71b40bff4acf146c6591c37c16b1a0c82d590403" alt=""
Folha2 (2º momento):
data:image/s3,"s3://crabby-images/92c10/92c10e677be5bb8ac842e08e53b2d7a7daeff665" alt=""
Podemos então, para conseguir este resultado:
1º – Definir o Range e atribuir-lhe um nome (no exemplo: "Vendas"):
data:image/s3,"s3://crabby-images/7537c/7537c44d51e93a4174bcc2f198b64cd278a24c13" alt=""
2º – Executar o seguinte Código num módulo VBE:
Sub TransferCells()
Const SOURCESHEETNAME As String = "Sheet1"
Const DESTSHEETNAME As String = "Sheet2"
Dim copyRange As Range
Dim cell As Range
Dim destinationRange As Range
Const DESTSHEETNAME As String = "Sheet2"
Dim copyRange As Range
Dim cell As Range
Dim destinationRange As Range
Worksheets(SOURCESHEETNAME).Select
Set destinationRange = Worksheets(DESTSHEETNAME).Range("A1")
For Each cell In Range("Vendas").Resize(, 1)
If cell.Value = "Vendas" Then
If copyRange Is Nothing Then
Range(cell, cell.Offset(0, 1)).Copy Destination:= _
Sheets("Sheet2").Range("A" & Rows.Count).End(xlUp).Offset(1, 0)
End If
End If
Next cell
If cell.Value = "Vendas" Then
If copyRange Is Nothing Then
Range(cell, cell.Offset(0, 1)).Copy Destination:= _
Sheets("Sheet2").Range("A" & Rows.Count).End(xlUp).Offset(1, 0)
End If
End If
Next cell
End Sub