Notifications
Clear all

Inserir a data do dia após filtrar resultados.

8 Posts
3 Usuários
0 Reactions
1,357 Visualizações
(@fabiosp)
Posts: 291
Reputable Member
Topic starter
 

Prezados Colegas bom dia.

Estou com um problema e necessito de ajuda dos mestres deste fórum.
Criei esta macro porém não sei como fazer para colocar a data na coluna H nomeada como DATA SAIDA no arquivo Lista geral2014 após a filtragem dos resultados.

O que eu fiz é o seguinte abro o arquivo Lista geral2014 rodo a macro ai ele abre outro arquivo nomeado como RELATORIOFEV2014 copia dados de todas colunas e cola no arquivo Lista geral2014 a partir da coluna F depois eu coloco em orbem númerica a coluna F e depois copio e colo na coluna A transforma texto em números e faço alinhamento das colunas depois chamo uma macro que compara a coluna A e B copiando números repetidos na coluna C.
Caso na coluna C tenha algum resultado e inserido um número 1 na coluna D depois e feito um filtro na coluna D para aparecer somente os resultados com número 1
Aparecendo os resultados tenho que inserir a data (do dia) na coluna H nomeada como DATA SAIDA.

Justamente essa última tarefa que não consegui fazer via macro e gostaria da ajuda dos colegas mestre em VBA.

Necessito que após a filtragem seja inserido a data do dia apenas nos resultado que aparecer com 1 após a filtragem

Estou anexando meus arquivos para análise.

Desde já agradeço e espero que algum colega possa me ajudar

Abraço a todos.

 
Postado : 04/02/2014 8:07 am
Wagner Morel
(@wagner-morel-vidal-nobre)
Posts: 0
Illustrious Member
 

Fabiosp,

Bom Dia!

Veja se é assim.

Desenvolvo pequenas soluções em VBA Excel a valores que variam entre R$ 50,00 a R$ 200,00. Se te interessar, entre no meu instagran (vba_excel_desenvolvimento)

Atenciosamente
Wagner Morel

 
Postado : 04/02/2014 8:40 am
(@fabiosp)
Posts: 291
Reputable Member
Topic starter
 

Olá prezado colega Wagner Morel.

Muito obrigado pela costumeira atenção.

Era isso mesmo que necessitava.

Está perfeito porém só mais uma dúvida.

Será que a rotina em evento Worksheet_Change que criei esta correta?

As vezes quando apago o resultado da coluna C o número`1`da coluna D não desaparece.

Desde já agradeço a ajuda e compreensão.

Abraços.

Abaixo segue o código:

Private Sub Worksheet_Change(ByVal Target As Range)
        
        Dim sValor
        
        If Not Intersect(Target, [C2:C1001]) Is Nothing Then
            sValor = Target.Value
            
            If sValor = "" Then
                Target.Offset(0, 1).Value = "1"
            Else
                Target.Offset(0, 1).Value = "1"
            End If

        End If
        
    End Sub

Sub COPIANDO()
'Declaração de variáveis
Dim i As Long
Dim UltimaLinha As Long

Range("F6").Select
Call convertendo_text_para_num

Application.ScreenUpdating = False
Application.Calculation = xlManual

    Workbooks.Open Filename:= _
        ActiveWorkbook.Path & "RELATORIOFEV2014.xls"
    Range("A5:E5").Select
    Range(Selection, Selection.End(xlDown)).Select
    Selection.Copy
    Windows("LISTA GERAL2014.xls").Activate
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=False
    Application.CutCopyMode = False
    With Selection
        .HorizontalAlignment = xlGeneral
        .VerticalAlignment = xlCenter
        .WrapText = False
        .Orientation = 0
        .AddIndent = False
        .IndentLevel = 0
        .ShrinkToFit = False
        .ReadingOrder = xlContext
        .MergeCells = False
    End With
    With Selection
        .HorizontalAlignment = xlCenter
        .VerticalAlignment = xlCenter
        .WrapText = False
        .Orientation = 0
        .AddIndent = False
        .IndentLevel = 0
        .ShrinkToFit = False
        .ReadingOrder = xlContext
        .MergeCells = False
    End With
    Range("F6:J6").Select
    Range(Selection, Selection.End(xlDown)).Select
    
    Selection.Sort Key1:=Range("F6"), Order1:=xlAscending, Header:=xlGuess, _
        OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom, SortMethod _
        :=xlPinYin, DataOption1:=xlSortNormal
    Range("F6").Select
    Range(Selection, Selection.End(xlDown)).Select
    Selection.Copy
   
    Range("A6").Select
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=False
    Application.CutCopyMode = False
    With Selection
        .HorizontalAlignment = xlGeneral
        .VerticalAlignment = xlCenter
        .WrapText = False
        .Orientation = 0
        .AddIndent = False
        .IndentLevel = 0
        .ShrinkToFit = False
        .ReadingOrder = xlContext
        .MergeCells = False
    End With
    With Selection
        .HorizontalAlignment = xlGeneral
        .VerticalAlignment = xlCenter
        .WrapText = False
        .Orientation = 0
        .AddIndent = False
        .IndentLevel = 0
        .ShrinkToFit = False
        .ReadingOrder = xlContext
        .MergeCells = False
    End With
    With Selection
        .HorizontalAlignment = xlCenter
        .VerticalAlignment = xlCenter
        .WrapText = False
        .Orientation = 0
        .AddIndent = False
        .IndentLevel = 0
        .ShrinkToFit = False
        .ReadingOrder = xlContext
        .MergeCells = False
    End With
    Range("F6").Select
    Range(Selection, Selection.End(xlDown)).Select
    Range("F6").Select
    Workbooks("RELATORIOFEV2014.xls").Save
    Workbooks("RELATORIOFEV2014.xls").Close
    
    Call Comparar
    Call FILTRAR
    
    Application.ScreenUpdating = True
    Application.Calculation = xlCalculationAutomatic
    
    'Inserindo a data do dia na coluna H
    UltimaLinha = Sheets("SAIDAS").Cells(Cells.Rows.Count, 1).End(xlUp).Row
    For i = 2 To UltimaLinha
        If Range("D" & i).Value = 1 Then Range("H" & i).Value = Date
    Next
    MsgBox "ACABOU"

End Sub


Sub Comparar()
Application.ScreenUpdating = False
Application.Calculation = xlManual

Dim Comparar As Variant
Dim x As Variant
Dim y As Variant

Set Comparar = Range("B1:B1000")

For Each x In Range("A1:A1000")
For Each y In Comparar
If x = y Then x.Offset(0, 2) = x
Next y
Next x
Application.ScreenUpdating = True
Application.Calculation = xlCalculationAutomatic

End Sub

Sub convertendo_text_para_num()

Application.ScreenUpdating = False
Application.Calculation = xlManual

For Each WS In Sheets
On Error Resume Next
For Each r In WS.UsedRange.SpecialCells(xlCellTypeConstants)
If IsNumeric(r) Then r.Value = Val(r.Value)
Next
Next

    Application.ScreenUpdating = True
    Application.Calculation = xlCalculationAutomatic


End Sub


Sub FILTRAR()

Cells.Select
Selection.AutoFilter
 Range("D1").Select
 Selection.AutoFilter Field:=4, Criteria1:="1"

End Sub
 
Postado : 04/02/2014 9:30 am
Wagner Morel
(@wagner-morel-vidal-nobre)
Posts: 0
Illustrious Member
 

Acho que o erro está nessas linhas (dentro do IF):
O que você está dizendo nesse IF é o seguinte:
1 - sValor armazena o que for digitado na célula ativa
2 - Se sValor não tiver nada (se não foi digitado nada na célula ativa), coloca na célula que fica na mesma linha, próxima coluna, o número 1.
3 - Caso contrário, ou seja, se sValor já tiver algo armazenado, também coloca na célula que fica na mesma linha, próxima coluna, o número 1.

É aí que não entendi... como pode atender a duas condições diferentes o mesmo número 1. No caso do Else, não seria, por exemplo, não fazer nada???

            sValor = Target.Value
           
            If sValor = "" Then
                Target.Offset(0, 1).Value = "1" 
            Else
                Target.Offset(0, 1).Value = "1"
            End If

Desenvolvo pequenas soluções em VBA Excel a valores que variam entre R$ 50,00 a R$ 200,00. Se te interessar, entre no meu instagran (vba_excel_desenvolvimento)

Atenciosamente
Wagner Morel

 
Postado : 04/02/2014 11:04 am
(@fabiosp)
Posts: 291
Reputable Member
Topic starter
 

Prezado colega Wagner Morel

Muito obrigado pela resposta espero algum dia retribuir sua generosidade.
Mas subistituindo o Else por fazer nada caso apague a informação da coluna C o número "1" não deveria sumir?
Seria necessário incluir um código?

Novamente agradeço sua ajuda caro colega.

Grande abraço.

 
Postado : 04/02/2014 5:09 pm
Wagner Morel
(@wagner-morel-vidal-nobre)
Posts: 0
Illustrious Member
 

Como eu disse, eu não entendi a lógica da sua programação...
Talvez seja isso:

Target.Offset(0, 1).Value = ""

Desenvolvo pequenas soluções em VBA Excel a valores que variam entre R$ 50,00 a R$ 200,00. Se te interessar, entre no meu instagran (vba_excel_desenvolvimento)

Atenciosamente
Wagner Morel

 
Postado : 04/02/2014 8:27 pm
(@fabiosp)
Posts: 291
Reputable Member
Topic starter
 

Boa noite caro colega Wagner Morel

muito obrigado pela ajuda!!

foi muito útil para poder concluir minha tarefa.

Abraços.

 
Postado : 04/02/2014 8:34 pm
Fernando Fernandes
(@fernandofernandes)
Posts: 43750
Illustrious Member
 

Caso seja necessário reabrir o tópico, o autor poderá enviar uma MP para um dos moderadores solicitando o desbloqueio.

Existem mil maneiras de preparar Neston. Invente a sua!
http://www.youtube.com/ExpressoExcel

 
Postado : 05/02/2014 7:26 am