Extracting Outlook messages metadata to Excel spreadsheet

peddy00

New Member
Joined
Aug 19, 2012
Messages
27
Hi,

I have 26 emails in a folder with path C:\Users\Peter\Desktop\New folder, all with the file extension .msg. I'd like to extract the sender, recipient, Cc, and other data from the emails, and set them in a spreadsheet. I found something that I thought would be helpful at a different forum (though, I don't need the body of the message in my spreadsheet), but I have a few problems with it.

First, how is that macro supposed to be called? When I'm in the VBA editor, and hit F5, the macro doesn't start.

Second, I can't see where I'm supposed to put the specific path I want to use into the code.

Third, just wanting to see what would happen, I deleted Path As String from the first line of the macro, then run the code, but the compiler gives me an error, saying that MyOutlook As Outlook.Application is a "User-defined type not defined."

Anyway, all I really care about is getting To, Cc, From, SentOn, and, if possible, a list of any attachments in the emails, I don't need the macro referred to above to work.

If this isn't clear, please feel free to ask for clarification. Thanks.

Peter
 

Excel Facts

Remove leading & trailing spaces
Save as CSV to remove all leading and trailing spaces. It is faster than using TRIM().
Hello Peter,

Can you please help me out, I know its been a while since you were dealing with this task, but I really could use some advise from you!
I have the same need as you did, so I have lots of Outlook .msg files in a folder and I want to extract their metadata to an Excel spreadsheet automatically.
I am new in VBA, so I just copy-pasted your code into a new module, changed the Path for my case, but while compiling I received an error message: "Sub or function is not defined".
What am I doing wrong?

Thanks for your time!

With Best Regards
Alexander
 
Upvote 0
Hello,

I'm trying to run this same code... with my own path attached to it, what I have looks like this:

Sub GetMailInfo()


Dim MyOutlook As Outlook.Application
Dim msg As Outlook.MailItem
Dim x As Namespace
Dim Path As String
Dim i As Long


Set MyOutlook = New Outlook.Application
Set x = MyOutlook.GetNamespace("MAPI")

Path = "C:\Users\gouveiar\TEST 2"
FileList = GetFileList(Path + "*.msg")


Row = 1


While Row <= UBound(FileList)


Set msg = x.OpenSharedItem(Path + FileList(Row))


Cells(Row + 1, 1) = msg.Subject
Cells(Row + 1, 2) = msg.SenderName
Cells(Row + 1, 3) = msg.SenderEmailAddress
Cells(Row + 1, 4) = msg.CC
Cells(Row + 1, 5) = msg.To
Cells(Row + 1, 6) = msg.SentOn
Cells(Row + 1, 7) = msg.Size
If msg.Attachments.Count > 0 Then
For i = 1 To msg.Attachments.Count
Cells(Row + 1, 7 + i) = msg.Attachments.Item(i).FileName
Next i
End If

Row = Row + 1
Wend


End Sub
Sub test()
Dim p As String, x As Variant


p = "C:\Users\gouveiar\TEST 2"
x = GetFileList(p)
Select Case IsArray(x)
Case True 'files found
MsgBox UBound(x)
Sheets("Sheet1").Range("A:A").Clear
For i = LBound(x) To UBound(x)
Sheets("Sheet1").Cells(i, 1).Value = x(i)
Next i
Case False 'no files found
MsgBox "No matching files"
End Select
End Sub






Function GetFileList(FileSpec As String) As Variant
' Taken from Excel Tips From John Walkenbach: Getting A List Of File Names Using VBA
' Returns an array of filenames that match FileSpec
' If no matching files are found, it returns False




Dim FileArray() As Variant
Dim FileCount As Integer
Dim FileName As String




On Error GoTo NoFilesFound




FileCount = 0
FileName = Dir(FileSpec)
If FileName = "" Then GoTo NoFilesFound




' Loop until no more matching files are found
Do While FileName <> ""
FileCount = FileCount + 1
ReDim Preserve FileArray(1 To FileCount)
FileArray(FileCount) = FileName
FileName = Dir()
Loop
GetFileList = FileArray
Exit Function




' Error handler
NoFilesFound:
GetFileList = False
End Function


The problem is that, my latest run stops at Row <= UBound and says I have a type 13 mismatch issue. Anyone could please help me with this???
Ana
 
Upvote 0

Forum statistics

Threads
1,225,479
Messages
6,185,229
Members
453,283
Latest member
Shortm88

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top