Хобрук: Ваш путь к мастерству в программировании

отправка таблицы данных с помощью Outlook API в С#

У меня есть таблица данных, и я хочу отправить ее по электронной почте с помощью API Outlook. Как мне это сделать?

пример кода было бы здорово. Я прикрепляю тем временем сообщение, которое хочу отправить

private Microsoft.Office.Interop.Outlook.MailItem mailItem; // an email item.

public void SetUpMessage(string SendTo,string CC, string subject, string messageBody,string Link)                
{
    app = new Microsoft.Office.Interop.Outlook.Application();
    mailItem = app.CreateItem(Microsoft.Office.Interop.Outlook.OlItemType.olMailItem);

    mailItem.To = SendTo;
    mailItem.CC = CC;
    mailItem.Subject = subject;
    mailItem.HTMLBody = messageBody + "<a href=\"" + Link + "\">Link</ID></a>";            
}

Ответы:


1

Я не уверен, какие данные у вас есть в таблице данных. Но если это простая текстовая таблица, вы можете использовать тег html table в своем htmlBody. Просто создайте простой цикл по столбцам таблицы данных, чтобы создать строку заголовка, а затем цикл по вашей ячейке, чтобы добавить значения.

краткая идея кода, учитывая, что datatable называется dtData (обратите внимание, я просто быстро написал это из головы, поэтому он может содержать один или два типа, но идея должна быть достаточно ясной)

                    StringBuilder table = new StringBuilder();                    
                    table.Append("<table style=\"width:100%\">\n<tr>\n");
                    int columnsCount = dtData.Columns.Count;
                    foreach (DataColumn column in dtData.Columns)
                    {
                        table.Append("<td>" + column.ColumnName + "</td>\n");
                    }
                    table.Append("</tr>\n");
                    foreach (DataRow row in dtData.Rows)
                    {
                        table.Append("<tr>\n");
                        for (int i = 0; i < columnsCount; i++)
                        {
                            table.Append("<td>" + row[i] + "</td>\n");
                        }
                        table.Append("</tr>\n");
                    }
                    table.Append("</table>\n");

                    //use table as your messagebody into given code
18.12.2014
  • StringBuilder лучше, чем строка, потому что много операций +=. 18.12.2014

  • 2

    Вы также можете рассмотреть возможность использования объектной модели Word для управления телом электронных писем. Глава 17. Работа с телами элементов статья подробно описывает все возможные способы.

    Также я бы рекомендовал использовать Resolve или ResolveAll для разрешить объект Recipient в адресной книге.

    Вы можете найти пример кода в Как создать и отправить сообщение Outlook программно.

    18.12.2014
    Новые материалы

    Создание кнопочного меню с использованием HTML, CSS и JavaScript
    Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

    Внедрите OAuth в свои веб-приложения для повышения безопасности
    OAuth — это широко распространенный стандарт авторизации, который позволяет приложениям получать доступ к ресурсам от имени пользователя, не раскрывая его пароль. Это позволяет пользователям..

    Классы в JavaScript
    class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

    Как свинг-трейдеры могут использовать ИИ для больших выигрышей
    По мере того как все больше и больше профессиональных трейдеров и активных розничных трейдеров узнают о возможностях, которые предоставляет искусственный интеллект и машинное обучение для улучшения..

    Как построить любой стол
    Я разработчик программного обеспечения. Я люблю делать вещи и всегда любил. Для меня программирование всегда было способом создавать вещи, используя только компьютер и мое воображение...

    Обзор: Машинное обучение: классификация
    Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

    Разработка расширений Qlik Sense с qExt
    Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..