boa noite !!!
Você precisará dessa macro que resolverá seus problemas
para que ela funcione, a celula A1 terá que estar a palavra operador, caso contrário, é so ajutar o range
segue a macro :
Sub SeparaPausa()
Dim W1 As Worksheet 'Declarando variável da primeira matriz
Dim W2 As Worksheet 'Declarando variável da segunda matriz
Dim iLinhaVendedor As Integer ' Variável que percorrerá as linhas dos vendedores
Dim iUltimaLinha As Integer ' Ultima linha da planilha destino
Dim bColunaMatriz As Byte ' varável que percorrerá as coluna da planilha destino
Dim bColunaCopia As Byte ' varável que percorrerá as colunas da cópia
'declarando as matrizes
Set W1 = Planilha1 ' matriz de origem dos dados
Set W2 = Planilha2 ' onde colocaremos os dados
' declarando variaveis
iLinhaVendedor = 2 ' a varredura começara na linha 2 da planilha1( a linha 1 é o cabeçalho)
iUltimaLinha = 2 ' a varredura começara na linha 2 da planilha2( a linha 1 é o cabeçalho)
' considerando que a planilha não seja zerada vamos localizar a última linha
While W2.Cells(iUltimaLinha, "A") <> "" 'loop para a ultima linha da planilha2
iUltimaLinha = iUltimaLinha + 1 'evitando loop eterno
Wend
' a cada 4 colunas vamos incrementar 1 linha
While W1.Cells(iLinhaVendedor, "A").Value <> "" ' loop para percorrer cada linha dos vendedores
W2.Cells(iUltimaLinha, "A").Value = W1.Cells(iLinhaVendedor, "A").Value ' grava o nome do vendedor
bColunaCopia = 2 'a copia começa na coluna B, na coluna A é o nome
bColunaMatriz = 2 ' idem, a coluna A é o nome
While W1.Cells(iLinhaVendedor, bColunaMatriz).Value <> "" ' loop para percorrer a coluna dos vendores e achar a palavra pausa do cabeçalho)
W2.Cells(iUltimaLinha, bColunaCopia).Value = W1.Cells(iLinhaVendedor, bColunaMatriz).Value 'copiando valor da planilha 1 para a planilha 3
If bColunaCopia = 4 Then 'aqui está a questão a cada 4 colunas precisamos mudar de linha,
bColunaCopia = 2 ' precisamos passar a coluna para B
W2.Cells(iUltimaLinha, "A").Value = W1.Cells(iLinhaVendedor, "A").Value ' copiar o nome do vendedor na col A
If bColunaMatriz < 13 Then ' precisamos verificar se está na ultima coluna da planilha1 para não gerar coluna em branco
iUltimaLinha = iUltimaLinha + 1 'incremento de linha
End If
Else
bColunaCopia = bColunaCopia + 1 ' incremento de coluna da panilha 3
End If
bColunaMatriz = bColunaMatriz + 1 ' íncrementa a coluna da planilha1
Wend
iUltimaLinha = iUltimaLinha + 1 ' incrementa a linha de destino
iLinhaVendedor = iLinhaVendedor + 1 ' incrementa a linha de vendedores (evita loop eterno)
Wend
End Sub
Espero que ajude
qualquer dúvida estou a disposição