Como Separar a Planilha de Excel com VBA?

Como Separar a Planilha de Excel com VBA?

Hoje vou mostrar uma função que criei para separar uma planilha em várias á partir de uma coluna com o ano e mês.

Para isso foi utilizado o seguinte código com os comentários:

'
'Divide a planilha em diversas a partir do critério do mês
Sub lsSeparaPlanilha()
    
    'Definição das Variáveis
    Dim iTotalLinhas As Integer
    Dim rngAux As Range
    Dim iAnoMes As String
    Dim lRow As Long
    Dim iTotalLinhasAux As Long
    Dim lCel As Long
    
    'Identifica a última linha da planilha
    iTotalLinhas = Cells(Rows.Count, 1).End(xlUp).Row
    
    'Seleciona os dados das colunas
    Columns("A:F").Select
    
    'Realiza a ordenação dos dados pela data
    ActiveWorkbook.Worksheets("Plan1").Sort.SortFields.Clear
    ActiveWorkbook.Worksheets("Plan1").Sort.SortFields.Add Key:=Range("F2:F" & iTotalLinhas) _
    , SortOn:=xlSortOnValues, Order:=xlAscending, DataOption:=xlSortNormal
    
    With ActiveWorkbook.Worksheets("Plan1").Sort
        .SetRange Range("A1:F" & iTotalLinhas)
        .Header = xlYes
        .MatchCase = False
        .Orientation = xlTopToBottom
        .SortMethod = xlPinYin
        .Apply
    End With
        
    'Analisa as linhas e as separa criando para isso novas planilhas
    For lCel = 2 To iTotalLinhas
        'Ativa a planilha da base de dados
        ActiveWorkbook.Worksheets("Plan1").Activate
        Set rngAux = Range("F" & CStr(lCel))
        
        'Cria uma nova planilha
        If Year(rngAux.Value) & "-" & Month(rngAux.Value)  iAnoMes Then
            Worksheets.Add(After:=Worksheets(Worksheets.Count)).Name = CStr(Year(rngAux.Value) & "-" & Month(rngAux.Value))
            iAnoMes = Year(rngAux.Value) & "-" & Month(rngAux.Value)
            ActiveWorkbook.Worksheets("Plan1").Activate
            Range("A1").EntireRow.Select
            Application.CutCopyMode = False
            Selection.Copy
            Sheets(CStr(iAnoMes)).Select
            Range("A1").Select
            ActiveSheet.Paste
        End If
        
        'Realiza a cópia dos dados
        ActiveWorkbook.Worksheets("Plan1").Activate
        rngAux.EntireRow.Select
        Application.CutCopyMode = False
        Selection.Cut
        Sheets(CStr(iAnoMes)).Select
        iTotalLinhas = Cells(Rows.Count, 1).End(xlUp).Row + 1
        Range("A" & CStr(iTotalLinhas)).Select
        ActiveSheet.Paste
        
    Next lCel
    
    'Avisa o usuário o término do processo
    MsgBox "Planilha Separada", vbInformation
    '
End Sub

Então é isso, acredito que esta macro possa ser adaptada a outras necessidades com poucas alterações, e agradeço a sua visita.

Marcos Rieper


Marcos Rieper

Pai, marido, professor e consultor em Excel.

Obrigado por ler este artigo, este blog foi criado para difundir o conhecimento em Excel à todos.

Divulgamos novos artigos nas redes sociais, basta clicar nos ícones abaixo.

Excel não precisa ser complicado

Assine nossa newsletter e receba dicas práticas para dominar o excel