Solved

Export Exchange Public Folder Data to CSV

Posted on 2008-10-01
5
647 Views
Last Modified: 2013-11-25
My client has created several custom forms through outllook on their exchange database (exchange 2000 public folders). They have added extra detail fields. I need to get all this information out of exchange and into a CSV, XML or any other transferrable format to import into an application we are developing for them.

Does anyone know of a simple way to do do this?
0
Comment
Question by:mansol2
  • 3
  • 2
5 Comments
 
LVL 76

Expert Comment

by:David Lee
ID: 22629896
Hi, mansol2.

Assuming that the data from the additional fields is being stored in user-properties, then I can do this with a simple bit of scripting.  Do you want just the custom fields or are there stock fields you want too?


0
 

Author Comment

by:mansol2
ID: 22631620
Bluedevilfan

I am looking for the stock fields too. Could you give me a couple of pointers or some sample script and I will try to do it myself.

Thanks

0
 
LVL 76

Accepted Solution

by:
David Lee earned 500 total points
ID: 22634852
Here's an export routine I wrote for another question.  This one exports appointments.  I've added comments to help you understand how it works.  Stock fields are referred to by their property name.  For example, an appointment item's starting time is in a property called Start.  Built-in properties are all documented in online help for the particular object type (i.e. message, task, appointment, etc.).  User-properties are stored in a collection called UserProperties.  Use code like this to get the value of a userproperty:

    varValue = Item.UserProperties.Item("MyUserPropertyName").Value

Where
varValue is a variable to hold the returned value
Item is any Outlook object (e.g. message, task, appointment, etc.)
MyUserPropertyName is the name of the property to be retrieved


Sub ExportAppointments()
    Const S1 = """"
    Const S2 = ""","""
    Dim olkItems As Outlook.Items, _
        olkAppt As Outlook.AppointmentItem, _
        objFSO As Object, _
        objFile As Object, _
        varBuffer As Variant
    'Open the folder that's currently selected in Outlook.  This makes the routine more flexible than opening a specific folder.'
    Set olkItems = Application.ActiveExplorer.CurrentFolder.Items
    'Loop to process each item in the folder.'
    For Each olkAppt In olkItems
        'Test to make sure that the item is of the desired type.'
        If olkAppt.Class = olAppointment Then
            With olkAppt
                'Build a CSV row for the current record.  The appointment fields are all stock fields.'
                varBuffer = varBuffer & S1 & .Subject & S2 & .Body & S2 & .Start & S2 & .End _
                    & S2 & .AllDayEvent & S1 & vbCrLf
            End With
        End If
    Next
    'Create a file and write the CSV data to it.'
    Set objFSO = CreateObject("Scripting.FileSystemObject")
    Set objFile = objFSO.CreateTextFile("C:\eeTesting\Calendar - " & olkItems.Parent.Parent.Name & ".csv")
    objFile.WriteLine varBuffer
    'Clean-up'
    objFile.Close
    Set objFile = Nothing
    Set objFSO = Nothing
    Set olkAppt = Nothing
    Set olkItems = Nothing
    MsgBox "All done!", vbInformation + vbOKOnly, "Export Appointments"
End Sub

Open in new window

0
 

Author Closing Comment

by:mansol2
ID: 31502274
Nice and clear - took me right back to my cBasic days - when 64K was enough memory to run an accounts program !!!
Thanks
0
 
LVL 76

Expert Comment

by:David Lee
ID: 22644073
You're welcome.  Glad I could help out.
0

Featured Post

Are your AD admin tools letting you down?

Managing Active Directory can get complicated.  Often, the native tools for managing AD are just not up to the task.  The largest Active Directory installations in the world have relied on one tool to manage their day-to-day administration tasks: Hyena. Start your trial today.

Question has a verified solution.

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

Find out what you should include to make the best professional email signature for your organization.
This article aims to explain the working of CircularLogArchiver. This tool was designed to solve the buildup of log file in cases where systems do not support circular logging or where circular logging is not enabled
In this video we show how to create a mailbox database in Exchange 2013. We show this process by using the Exchange Admin Center. Log into Exchange Admin Center.: First we need to log into the Exchange Admin Center. Navigate to the Servers >> Data…
The basic steps you have just learned will be implemented in this video. The basic steps are shown to configure an Exchange DAG in a live working Exchange Server Environment and manage the same (Exchange Server 2010 Software is used in a Windows Ser…

816 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

Need Help in Real-Time?

Connect with top rated Experts

12 Experts available now in Live!

Get 1:1 Help Now