Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

Finding the path to a calendar in outlook

Posted on 2008-10-16
13
Medium Priority
?
663 Views
Last Modified: 2012-05-05
I am not able to figure out what the path to my alternate calendar is.  The name of my calendar is "DSP Class Schedule"  When I'm in it, the address box in Outlook 2003 says:  outlook:Calendar\DSP Class Schedule , but if I use "Calendar\DSP Class Schedule" as the path when trying to post an appointment to it from Access, I get the error message: "The operation failed.  An object could not be found."   My personal folders folder is actually called "Personal Folder as of 7-25-08" and it appears that calendar/dsp class schedule is a subfolder in my personal folders folder.  So for the path I used:  "Personal Folder as of 7-25-08\Calendar\DSP Class Schedule" and got the same error.  I really need to figure out the path to my alternate calendar so I can have my Access database schedule an appointment in it.  Many thanks - Emma
'Create an appointment in the Outlook Calendar - THIS CODE PUTS IT IN THE DEFAULT CALENDAR
Dim objOutlook As Outlook.Application
Dim objAppt As Outlook.AppointmentItem
 
Set objOutlook = CreateObject("Outlook.Application")
 
'''Set objAppt = objOutlook.CreateItem(olAppointmentItem)
Set objFolder = OpenMAPIFolder("Personal Folders as of 7-25-08\Calendar\DSP Class Schedule")
Set objAppt = objFolder.Items.Add
 
With objAppt
    .Start = Me!Datehearing & " " & Me!Timehearing
    .Duration = 30
    .Subject = Me!ClientContactID.Column(4) & " foreclosure hearing."
    .ReminderSet = False
    .Save
    .Close (olSave)
End With
 
Set objAppt = Nothing   'Release the AppointmentItem object variable
 
Set objOutlook = Nothing    'Release the Outlook object variable

Open in new window

0
Comment
Question by:EmmaDSP
  • 6
  • 5
  • 2
13 Comments
 
LVL 28

Expert Comment

by:omgang
ID: 22736209
OM Gang
'Create an appointment in the Outlook Calendar - THIS CODE PUTS IT IN THE DEFAULT CALENDAR
Dim objOutlook As Outlook.Application
Dim olNS As Outlook.NameSpace
Dim olFolders As Outlook.MAPIFolder
Dim objFolder As Outlook.MAPIFolder
Dim objSubFolder As Outlook.MAPIFolder
Dim objAppt As Outlook.AppointmentItem
Dim strPST As String
 
strPST = "Personal Folders as of 7-25-08"
 
Set objOutlook = CreateObject("Outlook.Application")
Set olNS = olOutlook.GetNamespace("MAPI")
        'set object NameSpace Folders for PST file
Set olFolders = olNS.Folders(strPST)
 
'''Set objAppt = objOutlook.CreateItem(olAppointmentItem)
Set objFolder = olFolders.Folders("Calendar")
Set objSubFolder = objFolder.Folders("DSP Class Schedule")
Set objAppt = objSubFolder.Items.Add
 
With objAppt
    .Start = Me!Datehearing & " " & Me!Timehearing
    .Duration = 30
    .Subject = Me!ClientContactID.Column(4) & " foreclosure hearing."
    .ReminderSet = False
    .Save
    .Close (olSave)
End With
 
Set objAppt = Nothing   'Release the AppointmentItem object variable
Set objSubFolder = Nothing
Set objFolder = Nothing
Set olFolders = Nothing
Set olNS = Nothing
Set objOutlook = Nothing    'Release the Outlook object variable

Open in new window

0
 

Author Comment

by:EmmaDSP
ID: 22737012
When it hits this statement:  Set olNS = olOutlook.GetNamespace("MAPI")    (line 13 above) it gives me the error:  Object Required.    I have not idea if the folder name is part of the problem:  do you know how I can just rename it back to Personal Folders or Personal Folder (whatever the default is) rather than that odd folder name I gave it some time ago?  Many thanks - Emma
0
 
LVL 59

Expert Comment

by:Chris Bottomley
ID: 22738008
Try replacing:

Set objFolder = OpenMAPIFolder("Personal Folders as of 7-25-08\Calendar\DSP Class Schedule")
with
Set objFolder = objOutlook..GetNamespace("MAPI").GetDefaultFolder(olFolderCalendar).Folders("Personal Folders as of 7-25-08\Calendar\DSP Class Schedule")

Chris
'Create an appointment in the Outlook Calendar - THIS CODE PUTS IT IN THE DEFAULT CALENDAR
Dim objOutlook As Outlook.Application
Dim objAppt As Outlook.AppointmentItem
 
Set objOutlook = CreateObject("Outlook.Application")
 
'''Set objAppt = objOutlook.CreateItem(olAppointmentItem)
Set objFolder = objOutlook..GetNamespace("MAPI").GetDefaultFolder(olFolderCalendar).Folders("Personal Folders as of 7-25-08\Calendar\DSP Class Schedule")
Set objAppt = objFolder.Items.Add
 
With objAppt
    .Start = Me!Datehearing & " " & Me!Timehearing
    .Duration = 30
    .Subject = Me!ClientContactID.Column(4) & " foreclosure hearing."
    .ReminderSet = False
    .Save
    .Close (olSave)
End With
 
Set objAppt = Nothing   'Release the AppointmentItem object variable
 
Set objOutlook = Nothing    'Release the Outlook object variable

Open in new window

0
Nothing ever in the clear!

This technical paper will help you implement VMware’s VM encryption as well as implement Veeam encryption which together will achieve the nothing ever in the clear goal. If a bad guy steals VMs, backups or traffic they get nothing.

 
LVL 59

Expert Comment

by:Chris Bottomley
ID: 22738014
Apologies .. I see a double dot in the statement now ... obviously only use one dot at each position i.e.

Set objFolder = objOutlook.GetNamespace("MAPI").GetDefaultFolder(olFolderCalendar).Folders("Personal Folders as of 7-25-08\Calendar\DSP Class Schedule")

Chris
0
 

Author Comment

by:EmmaDSP
ID: 22739216
Hi, Chris. Using your code above I'm back to the error message "The operation failed. An object could not be found."  BUT, both of you have given me some possibilities of how to specify the desired folder and perhaps I can make my original code work now.  Unfortunately, I won't be able to work on this until later today.  I'm open to any other suggestions, and I'll post here again when I've had time to work with the code some more (later today, hopefully).  Many, many thanks. - Emma
0
 
LVL 59

Expert Comment

by:Chris Bottomley
ID: 22739284
In your original code you used objFolder, I re-used it but there is no definition of objFolder  in the snippet ... are you sure it is defined something like:

dim objFolder as outlook.mapifolder?

Chris
0
 

Author Comment

by:EmmaDSP
ID: 22739415
Hi, Chris.  Yes, that dim statement does exist in my code.  Thanks! - Emma
0
 
LVL 59

Expert Comment

by:Chris Bottomley
ID: 22739533
Sorry to be pedantic but it seems to be the only thing that can justify object not found so my apologies for questioning you but are you certain that the declaration is in scope for the code snippet as supplied?

Beyond this the only other thing I can think of is "Personal Folders as of 7-25-08\Calendar\DSP Class Schedule" are you certain this ius the exact spelling and presentation of the folder in the outlook folders display?

Chris
0
 

Author Comment

by:EmmaDSP
ID: 22739597
Hi, Chris. I totally understand your question: I'd like to be able to "copy" and then "paste" the folder name, so I'm sure it's exactly the folder name, but I can't find a place where "copy" works.  I have to go to meetings now.  I'll work on this again later today (hopefully) and see if I can meet with some success.  I'll post back here with status and/or info at that time.  Thanks much! - Emma
0
 
LVL 59

Expert Comment

by:Chris Bottomley
ID: 22739961
If you can provide a snapshot of the folderpath then that would be good otherwise in outlook, select the calendar and in the immediate window of the VBE type:

print application.ActiveExplorer.CurrentFolder.FolderPath

Hopefully that will confirm the main path leaving the active calendar name to append.

Supply th elot and see what to make of it.

Chris
0
 
LVL 28

Accepted Solution

by:
omgang earned 2000 total points
ID: 22741095
<<When it hits this statement:  Set olNS = olOutlook.GetNamespace("MAPI")    (line 13 above) it gives me the error:  Object Required.    I have not idea if the folder name is part of the problem:  do you know how I can just rename it back to Personal Folders or Personal Folder (whatever the default is) rather than that odd folder name I gave it some time ago?  Many thanks - Emma >>

Sorry about that Emma, I reused some existing code I have and missed that variable name change.  Try

Set olNS = objOutlook.GetNamespace("MAPI")

OM Gang

0
 

Author Closing Comment

by:EmmaDSP
ID: 31507295
Thank you so much, OM Gang.  It worked!  I can't tell you how happy I am to finally have this matter resolved.  Thanks for your help! - Emma
0
 

Author Comment

by:EmmaDSP
ID: 22744959
Thank you, OM Gang.  That worked!  The appointment is finally appearing in my alternate (non-default) calendar.  Many thanks. - Emma
0

Featured Post

Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

When you have clients or friends from around the world, it becomes a challenge to arrange a meeting or effectively manage your time. This is where Outlook's capability to show 2 time zones in one calendar comes in handy.
If you troubleshoot Outlook for clients, you may want to know a bit more about the OST file before doing your next job. IMAP can cause a lot of drama if removed in the accounts without backing up.
A short tutorial showing how to set up an email signature in Outlook on the Web (previously known as OWA). For free email signatures designs, visit https://www.mail-signatures.com/articles/signature-templates/?sts=6651 If you want to manage em…
This is my first video review of Microsoft Bookings, I will be doing a part two with a bit more information, but wanted to get this out to you folks.

885 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question