Udostępnij za pośrednictwem


Porady: Programowane wysyłanie wiadomości e-mail

W tym przykładzie wysyła wiadomość e-mail do kontaktów, które mają nazwę domeny example.com w ich adresów e-mail.

Zastosowanie: Informacje przedstawione w tym temacie mają zastosowanie do projektów na poziomie aplikacji obsługiwanych w programach Outlook 2013 i Outlook 2010. Aby uzyskać więcej informacji, zobacz Funkcje dostępne w aplikacjach pakietu Office i typ projektu.

Przykład

Private Sub ThisAddIn_Startup(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Startup
    SendEmailtoContacts()
End Sub 

Private Sub SendEmailtoContacts()
    Dim subjectEmail As String = "Meeting has been rescheduled." 
    Dim bodyEmail As String = "Meeting is one hour later." 
    Dim sentContacts As Outlook.MAPIFolder = Me.Application.ActiveExplorer() _
        .Session.GetDefaultFolder(Outlook _
        .OlDefaultFolders.olFolderContacts)
    For Each contact As Outlook.ContactItem In sentContacts.Items()
        If contact.Email1Address.Contains("example.com") Then
            CreateEmailItem(subjectEmail, contact _
            .Email1Address, bodyEmail)
        End If 
    Next 
End Sub 

Private Sub CreateEmailItem(ByVal subjectEmail As String, _
    ByVal toEmail As String, ByVal bodyEmail As String)
    Dim eMail As Outlook.MailItem = Me.Application.CreateItem _
        (Outlook.OlItemType.olMailItem)
    With eMail
        .Subject = subjectEmail
        .To = toEmail
        .Body = bodyEmail
        .Importance = Outlook.OlImportance.olImportanceLow
        .Send()
    End With 
End Sub
private void ThisAddIn_Startup(object sender, System.EventArgs e)
{
    SendEmailtoContacts();
}

private void SendEmailtoContacts()
{
    string subjectEmail = "Meeting has been rescheduled.";
    string bodyEmail = "Meeting is one hour later.";
    Outlook.MAPIFolder sentContacts = (Outlook.MAPIFolder)
        this.Application.ActiveExplorer().Session.GetDefaultFolder
        (Outlook.OlDefaultFolders.olFolderContacts);
    foreach (Outlook.ContactItem contact in sentContacts.Items)
    {
        if (contact.Email1Address.Contains("example.com"))
        {
            this.CreateEmailItem(subjectEmail, contact
                .Email1Address, bodyEmail);
        }
    }
}

private void CreateEmailItem(string subjectEmail,
       string toEmail, string bodyEmail)
{
    Outlook.MailItem eMail = (Outlook.MailItem)
        this.Application.CreateItem(Outlook.OlItemType.olMailItem);
    eMail.Subject = subjectEmail;
    eMail.To = toEmail;
    eMail.Body = bodyEmail;
    eMail.Importance = Outlook.OlImportance.olImportanceLow;
    ((Outlook._MailItem)eMail).Send();
}

Kompilowanie kodu

W tym przykładzie wymaga:

  • Kontakty, które mają nazwy domeny example.com w ich adresów e-mail.

Stabilne programowanie

Nie usuwaj kodu filtr, który wyszukuje nazwy domeny example.com.Rozwiązanie będzie wysyłać wiadomości e-mail do wszystkich kontaktów, jeśli usunąć filtr.

Zobacz też

Zadania

Porady: Programowane tworzenie elementu poczty e-mail

Porady: Programowane uzyskiwanie dostępu do kontaktów programu Outlook

Poradnik: Programowane wykonywanie akcji po otrzymaniu wiadomości e-mail

Koncepcje

Praca z elementami poczty