![]() |
how not close both Outlooks?
Thanks in advance.
I have an Excel macro that opens Outlook with 'shell' and set objOutlook=createObject, then closes it with objOutlook.Quit. But if I have two Outlooks open (one that was already open, and one more that was opened by the macro), the objOutlook.Quit closes them both. Is it possible to just close one? Thanks again. |
how not close both Outlooks?
"Ian Elliott" wrote in message ...
Thanks in advance. I have an Excel macro that opens Outlook with 'shell' and set objOutlook=createObject, then closes it with objOutlook.Quit. But if I have two Outlooks open (one that was already open, and one more that was opened by the macro), the objOutlook.Quit closes them both. Is it possible to just close one? Thanks again. Hi Ian, I put this at the top of the code module where I interact with Outlook 'Declarations section Option Explicit Option Base 1 Public objOutlook As Outlook.Application Public objNamespace As Outlook.NameSpace Public OutlookWasRunning As Boolean 'Interface with Outlook objects required will be through this sub. 'It is called by any sub requiring access to Outlook. Public Sub DeclareOutlookObjects() Application.ScreenUpdating = False On Error Resume Next Err.Clear Set objOutlook = GetObject(, "Outlook.Application") 'If Outlook is already open, flag it with Boolean If Err.Number < 0 Then OutlookWasRunning = False Else OutlookWasRunning = True end if On Error GoTo 0 Err.Clear 'keep err tidy If Not OutlookWasRunning Then Set objOutlook = CreateObject("Outlook.Application") 'fresh version of Outlook End If Set objNamespace = objOutlook.GetNamespace("MAPI") objNamespace.Logon 'may not be needed End Sub 'Releases Public variable objects after Outlook session Public Sub ReleaseOutlookObjects() Application.ScreenUpdating = False objNamespace.Logoff Set objNamespace = Nothing If Not OutlookWasRunning Then objOutlook.Quit Set objOutlook = Nothing End Sub You can call the first sub before creating messages etc and the second when you are finished. There is only ever one copy of Outlook open - why have two? regards Paul |
All times are GMT +1. The time now is 08:21 PM. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
ExcelBanter.com