no excel, como posso alterar automaticamente o conteúdo de uma célula se for igual a um determinado valor

0

Atualmente, estou trabalhando com uma coluna de dados (números) que corresponde a um conjunto de valores, e queria saber como eu poderia substituir automaticamente os dados / números com o valor correspondente correto? (forneceu uma imagem do que quero dizer abaixo) obrigado pela sua ajuda!

Dados iniciais

Resultadofinal

    
por lacrosse1991 25.01.2013 / 16:49

1 resposta

1

No evento de alteração da planilha, você pode fazer algo assim. Ele supõe que a coluna na qual você está fazendo a entrada é A e o layout de suas pesquisas está em K & J, de acordo com seu exemplo. Você pode ajustar os intervalos como quiser.

Private Sub Worksheet_Change(ByVal Target As Range)
  'should check you are doing entry in column A first
If Target.Column = 1 Then
 Application.EnableEvents = False
 Dim R1 As Range
 Dim R2 As Range
 Dim rngStart As Range
 Dim varFind As Variant
 Dim InRange As Boolean
   Set R1 = Range(Target.Address)
    Set R2 = Range("J:J")
      Set rngStart = Range("J1")

   If R2.Find(What:=Target, After:=rngStart, LookIn:=xlValues, LookAt:=xlWhole _
    , SearchOrder:=xlByColumns, SearchDirection:=xlNext, MatchCase:=False, SearchFormat:=False) Is Nothing Then

     Application.EnableEvents = True
        Set R1 = Nothing
        Set R2 = Nothing

     Exit Sub
   Else
    varFind = R2.Find(What:=Target, After:=rngStart, LookIn:=xlValues, LookAt:=xlWhole _
    , SearchOrder:=xlByColumns, SearchDirection:=xlNext, MatchCase:=False, SearchFormat:=False).Address

      Set varFind = Range(varFind)
        R1.Value = varFind.Offset(0, -1)
   Application.EnableEvents = True
      Set R1 = Nothing
      Set R2 = Nothing
      Set rngStart = Nothing
      Set varFind = Nothing
   End If
  Else
    Exit Sub
 End If
End Sub
    
por 25.01.2013 / 22:16