Função SubTotal com Condição VBA

Objetivo: Utilizar a função subtotal com uma condição de igualdade. Exemplo: Quantidade de veículos Gol em um intervalo de dados com filtro, ou a soma dos valores dos veículos GOL filtrados no intervalo.

A função subtotal tem por objetivo trabalhar com várias funções em dados filtrados, mas ás vezes é necessário que estas informações sejam filtradas  mesmo na exibição dos dados, como é o caso da figura acima, aonde estão sendo contados apenas os veículos GOL e somado apenas o valor destes mesmos veículos.

A função VBA abaixo realiza o retorno de um intervalo de dados que atende ao critério de filtro, sendo desta forma utilizado no lugar da seleção dos dados na função SubTotal.

'fSubTotalCondicao
'Esta função traz um range de dados conforme a condição determinada
'lRange = intervalo de busca de dados
'lRngValor = intervalo de valores para funções diferentes de contagem
Function fSubTotalCondicao(ByVal lRange As Range, ByVal vValor As Variant, Optional ByVal lRngValor As Range) As Range

    Application.Volatile

    Dim lRangeSelect    As Range
    Dim lRng            As Range
    Dim lCel            As Range
    Dim lSelect         As Range
    Dim lCol            As Long

    Set lRangeSelect = lRange.SpecialCells(xlCellTypeVisible)

    If lRngValor Is Nothing Then
        For Each lCel In lRangeSelect
            If lCel.Value = vValor Then
                If fSubTotalCondicao Is Nothing Then
                    Set fSubTotalCondicao = Range(CStr(lCel.Address))
                Else
                    Set fSubTotalCondicao = Union(Range(CStr(lCel.Address)), Range(CStr(fSubTotalCondicao.Address)))
                End If
            End If
        Next lCel
    Else
        lCol = lRngValor.Column
        For Each lCel In lRangeSelect
            If lCel.Value = vValor Then
                If fSubTotalCondicao Is Nothing Then
                    Set fSubTotalCondicao = Range(CStr(Cells(lCel.Row, lCol).Address))
                Else
                    Set fSubTotalCondicao = Union(Range(CStr(Cells(lCel.Row, lCol).Address)), Range(CStr(fSubTotalCondicao.Address)))
                End If
            End If
        Next lCel
    End If
End Function

A utilização da função é a seguinte:

fSubTotalCondicao(ByVal lRange As Range, ByVal vValor As Variant, Optional ByVal lRngValor As Range) As Range

  • lRange = Intervalo aonde será realizado o filtro
  • vValor = Valor que será filtrado
  • lRngValor = Intervalo aonde serão aplicadas opções diferentes de contagem, tal como soma por exemplo. Este parâmetro é opcional.

Para implementá-la você deve seguir o artigo: http://guiadoexcel.com.br/criando-funcoes-proprias-globais.

Abaixo o download do exemplo:

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