About Me

A minha fotografia
JRod - PORTUGAL
Microsoft [MVP] - Excel (10º ano consecutivo)
Ver o meu perfil completo
Com tecnologia do Blogger.

Seguidores

Estatisticas

Free Blog Counter

eXTReMe Tracker
Ocorreu um erro neste dispositivo
2007-03-28

Uma pequena adaptação ao post anterior para mostrar como é que se pode apresentar, no comentário, quantos dias já passaram sobre determinada data (cfr. exemplo):

 

 

O Código, adaptado:

 

Private Sub Workbook_Open()
    Dim r As Long
    Dim temp, temp1 As String

    temp = "Atenção!!! Já passaram "

    temp1 = " dias sobre o início da baixa!"


    For r = Range("C1:C10").Count To 1 Step -1
        Range("C" & r).ClearComments

        If Range("C" & r) > 26 Then
            Range("C" & r).Interior.ColorIndex = 5
            Range("C" & r).AddComment
            Range("C" & r).Comment.Text Text:=temp & Range("C" & r) & temp1
            Range("C" & r).Comment.Visible = True
        Else
            Range("C" & r).Interior.ColorIndex = xlNone
            Range("C" & r).ClearComments
        End If
    Next r

End Sub
2007-03-20

Se pretendermos, ao abrir um workbook, que a célula (resultado da diferença entre duas datas) que contenha um resultado igual ou superior a x dias (no exemplo, 27) apresente uma coloração ( no exemplo, azul) e um comentário, que desaparecerão (coloração e comentário) se a diferença for inferior,  como no exemplo:

 

 

podemos utilizar o seguinte Código:
 
Private Sub Workbook_Open()
    Dim r As Long
    Dim temp As String

    temp = "Atenção!!! Já passaram mais do que 27 dias sobre o início da baixa!"


    For r = Range("C1:C10").Count To 1 Step -1
        Range("C" & r).ClearComments

        If Range("C" & r) > 26 Then
            Range("C" & r).Interior.ColorIndex = 5
            Range("C" & r).AddComment
            Range("C" & r).Comment.Text Text:=temp
            Range("C" & r).Comment.Visible = True
        Else
            Range("C" & r).Interior.ColorIndex = xlNone
            Range("C" & r).ClearComments
        End If
    Next r

End Sub

 

NOTA: O Código deve ser inserido no próprio workbook:

 

2007-03-17
 
Num newsgroup de Excel, perguntou-se como se poderia criar uma mensagem no Outlook, para avisar determinada pessoa, que já passaram mais do que três dias sobre a data limite e que, por, isso, essa pessoa deveria contactar os serviços, com urgência.
 
Supondo que, em A1, temos a data inicial, ou seja, a data limite (no exemplo: 07-03-2007) e que, em B1, temos a data actual, representada pela fórmula =TODAY()
 
Então, em C1, teremos o resultado da diferença entre B1 e A1, ou seja, a fórmula =B1-A1
 
E, para identificarmos a pessoa que está em falta, através do seu endereço de e-mail, no caso de já estar fora dos parâmetros introduzidos, colocamos, em F1, a seguinte fórmula:
 
=IF(C1>3;"jordao@junior.com";"")
 
Vejamos a imagem do exemplo:
 
Criamos agora um botão de comando, que há-de conter o seguinte código:
 

Private Sub CommandButton1_Click()
    Dim oOutlook As Object
    Dim oMailItem As Object
    Dim oRecipient As Object
    Dim oNameSpace As Object

    Set oOutlook = CreateObject("Outlook.Application")
    Set oNameSpace = oOutlook.GetNameSpace("MAPI")
    oNameSpace.Logon , , True


    Set oMailItem = oOutlook.CreateItem(0)
    Set oRecipient = _
    oMailItem.Recipients.Add(Range("F1").Value)
    oRecipient.Type = 1


    With oMailItem
        .Subject = "ATENÇÃO!"
        .Body = "Já passaram mais de 3 dias! Contacte o Serviço com urgência!"
        .Display
    End With

End Sub

 

O resultado será este:

 

2007-03-09
Se pretendermos obter numa célula, apenas com um duplo click, o valor total resultante da soma de um Range variável, na mesma coluna, Range esse que se inicie na 2ª linha e termine na linha imediatamente anterior à célula onde queremos o total, como no exemplo:
 
 
podemos utilizar o seguinte Código:
 

Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
    Dim name As String
    Dim name1 As String
    Dim name2 As String
    Dim Start As Long
    
    Cancel = True
    
    name = ActiveCell.Address
    name1 = Left(name, 2)
    name2 = ActiveCell.End(xlUp).Address
    Start = 2
    Range(name).Formula = _
    "=SUM(" & name1 & Start & ":" & name2 & ")"
End Sub

 

Nota: A variável Start tem o valor 2, para que o Range se inicie na 2ª linha e não na primeira, em virtude de haver cabeçalho na coluna. Para que a célula não fique activa ao dar-se o duplo click, deu-se a condição True à Propriedade Cancel.

2007-03-03

Se num determinado Range pretendermos encontrar a primeira célula vazia, entre várias células preenchidas e vazias, como no exemplo,

podemos utilizar um pouco de código VBE, de modo a, por um lado, termos uma mensagem a dizer-nos qual é a célula e, de seguida, posicionarmo-nos nessa mesma célula.

 

O Código:

Option Explicit


Sub FindFirstEmptyCell()

    Dim myRange As Range

    On Error Resume Next
    Set myRange = Range("A:B").SpecialCells(xlCellTypeBlanks)(1)
    On Error GoTo 0


    If myRange Is Nothing Then
        MsgBox "Não existem células vazias no Range!"
    Else
        MsgBox myRange.Address
    End If

    Range(myRange.Address).Select

End Sub