currently my application is pulling in all unread emails from my Outlook and displaying them in the datagridview. What is causing me a boat load of stress is the error: "System.__ComObject" that is showing up in the "Attachment" column.
All I'm trying to do is get the attachment names from unread Outlook emails into the attachment column.
Any help would be great, thank you.
- private void Form1_Load(object sender, EventArgs e)
- {
-
- try
- {
- Outlook._Application app = new Outlook.Application();
- Outlook.NameSpace ns = app.GetNamespace("MAPI");
- Outlook.MAPIFolder inbox = ns.GetDefaultFolder(Outlook.OlDefaultFolders.olFolderInbox);
- Outlook.Items UnRead = inbox.Items.Restrict("[Unread]=true");
-
- ns.SendAndReceive(true);
-
- dt = new DataTable("Inbox");
- dt.Columns.Add("From Email", typeof(String));
- dt.Columns.Add("Date", typeof(String));
- dt.Columns.Add("Subject", typeof(String));
- dt.Columns.Add("Body", typeof(String));
- dt.Columns.Add("Attachments", typeof(String));
- dt.Columns.Add("Print Body", typeof(String));
- dt.Columns.Add("File Format", typeof(String));
- dt.Columns.Add("Selected", typeof(String));
-
- dataGridView1.DataSource = dt;
- foreach (Object item in inbox.Items)
- {
- if ((item as Outlook.MailItem) != null && (item as Outlook.MailItem).UnRead == true)
- {
- Outlook.MailItem item1 = (Outlook.MailItem)item;
-
- dt.Rows.Add(new Object[] { item1.SenderName, item1.SentOn.ToLongDateString() + "" + item1.SentOn.ToLongTimeString(), item1.Subject,
- item1.Body, item1.Attachments});
- }
- }
- MessageBox.Show("Retrieving Unread Email Messages.");
- }
- catch (Exception ex)
- {
- MessageBox.Show(ex.Message, "Message", MessageBoxButtons.OK, MessageBoxIcon.Error);
- }
-
-
- }