Outlook Folders and Mail count

stuartjohnwood

New Member
Joined
Jun 7, 2010
Messages
24
Gentlefolks,

I need an Outlook VBA that can export a list of my Outlook folders and sub folders with a count of how many mails are within each. I know all that info is available but have no idea how to go about stringing it together.

Any help from out there would be hugely appreciated.

Best regards

SJW
 

Excel Facts

Do you hate GETPIVOTDATA?
Prevent GETPIVOTDATA. Select inside a PivotTable. In the Analyze tab of the ribbon, open the dropown next to Options and turn it off
Let me try again!

Create a new workbook and paste this code into a new standard module. Go Tools > References and add Microsoft Outlook Objects Library. Run ListFolders.

Code:
[FONT=Fixedsys]Option Explicit[/FONT]
[FONT=Fixedsys][/FONT] 
[FONT=Fixedsys]Dim ws As Worksheet
Dim iRow As Integer
Const bTitles As Boolean = True [COLOR=green]' do we want column titles?[/COLOR][/FONT]
[FONT=Fixedsys][/FONT] 
[FONT=Fixedsys]Public Sub ListFolders()[/FONT]
[FONT=Fixedsys][/FONT] 
[FONT=Fixedsys]  Dim objNS As Outlook.Namespace
  
  Set ws = ThisWorkbook.Sheets("Sheet1")
  Set objNS = Outlook.Application.GetNamespace("MAPI")
  
  ws.UsedRange.ClearContents
  iRow = IIf(bTitles, 1, 0)
  If bTitles Then ws.Range("A1:D1") = Array("Folder Path & Name", "Items", "", "Indented List Of Folders")
  ws.Range("A1:D1").Font.Bold = bTitles
  
  ListFromFolder objNS, 1, ""
  
  ws.Cells(iRow + 1, 2) = "=SUM(B" & IIf(bTitles, "2", "1") & ":B" & CStr(iRow) & ")"
  ws.UsedRange.ColumnWidth = 4
  ws.Columns("A:B").AutoFit
  
  MsgBox "Done:-" & vbCrLf & vbCrLf _
       & CStr(iRow - IIf(bTitles, 1, 0)) & " folders listed" & Space(15) & vbCrLf & vbCrLf _
       & Format(ws.Cells(iRow + 1, 2), "#,##0") & " items counted", _
       vbOKOnly + vbInformation
  
  Set objNS = Nothing
  Set ws = Nothing
  
End Sub[/FONT]
[FONT=Fixedsys][/FONT] 
[FONT=Fixedsys]Private Sub ListFromFolder(objFolderRoot As Object, argLevel As Integer, argFullName As String)[/FONT]
[FONT=Fixedsys][/FONT] 
[FONT=Fixedsys]  Dim objFolder As MAPIFolder
  
  For Each objFolder In objFolderRoot.Folders
    DoEvents
    iRow = iRow + 1
    ' full folder path in column A
    ws.Cells(iRow, 1) = argFullName & "\" & objFolder.Name
    ' count of items in folder in column B
    On Error Resume Next
    ws.Cells(iRow, 2) = objFolder.Items.Count
    On Error GoTo 0
    ' indented folder list in column C onwards
    ws.Cells(iRow, argLevel + 3) = objFolder.Name
    If objFolder.Folders.Count > 0 Then
      ListFromFolder objFolder, argLevel + 1, argFullName & "\" & objFolder.Name[/FONT]
[FONT=Fixedsys]    End If
  Next objFolder 
  
  Set objFolder = Nothing[/FONT]
[FONT=Fixedsys][/FONT] 
[FONT=Fixedsys]End Sub[/FONT]
 
Upvote 0
Just on the off chance,

Is there a way to modify this formula to change the order in which it works through the folders?

ie first it runs through all the Public folders (of which in my case, there are over 9000) before getting to my mailbox folders.

Ideally, I'd want to do my folders first.

Stuart
 
Upvote 0
Not as far as I'm aware. You could sort the worksheet but that's not the same thing at all, I accept.
 
Upvote 0
Hi,
I know this is an old thread, however, I have a question and I am hoping someone maybe able to answer it for me. I used the code above and it worked brillantly. I do not write code and I am wondering if code can be added to this one that will also pull the oldest email date from each folder. I would greatly appreciate your help. Thanks

Let me try again!

Create a new workbook and paste this code into a new standard module. Go Tools > References and add Microsoft Outlook Objects Library. Run ListFolders.

Code:
[FONT=Fixedsys]Option Explicit[/FONT]
 
[FONT=Fixedsys]Dim ws As Worksheet
Dim iRow As Integer
Const bTitles As Boolean = True [COLOR=green]' do we want column titles?[/COLOR][/FONT]
 
[FONT=Fixedsys]Public Sub ListFolders()[/FONT]
 
[FONT=Fixedsys] Dim objNS As Outlook.Namespace
  
  Set ws = ThisWorkbook.Sheets("Sheet1")
  Set objNS = Outlook.Application.GetNamespace("MAPI")
  
  ws.UsedRange.ClearContents
  iRow = IIf(bTitles, 1, 0)
  If bTitles Then ws.Range("A1:D1") = Array("Folder Path & Name", "Items", "", "Indented List Of Folders")
  ws.Range("A1:D1").Font.Bold = bTitles
  
  ListFromFolder objNS, 1, ""
  
  ws.Cells(iRow + 1, 2) = "=SUM(B" & IIf(bTitles, "2", "1") & ":B" & CStr(iRow) & ")"
  ws.UsedRange.ColumnWidth = 4
  ws.Columns("A:B").AutoFit
  
  MsgBox "Done:-" & vbCrLf & vbCrLf _
       & CStr(iRow - IIf(bTitles, 1, 0)) & " folders listed" & Space(15) & vbCrLf & vbCrLf _
       & Format(ws.Cells(iRow + 1, 2), "#,##0") & " items counted", _
       vbOKOnly + vbInformation
  
  Set objNS = Nothing
  Set ws = Nothing
  
End Sub[/FONT]
 
[FONT=Fixedsys]Private Sub ListFromFolder(objFolderRoot As Object, argLevel As Integer, argFullName As String)[/FONT]
 
[FONT=Fixedsys] Dim objFolder As MAPIFolder
  
  For Each objFolder In objFolderRoot.Folders
    DoEvents
    iRow = iRow + 1
    ' full folder path in column A
    ws.Cells(iRow, 1) = argFullName & "\" & objFolder.Name
    ' count of items in folder in column B
    On Error Resume Next
    ws.Cells(iRow, 2) = objFolder.Items.Count
    On Error GoTo 0
    ' indented folder list in column C onwards
    ws.Cells(iRow, argLevel + 3) = objFolder.Name
    If objFolder.Folders.Count > 0 Then
      ListFromFolder objFolder, argLevel + 1, argFullName & "\" & objFolder.Name[/FONT]
[FONT=Fixedsys]   End If
  Next objFolder 
  
  Set objFolder = Nothing[/FONT]
 
[FONT=Fixedsys]End Sub[/FONT]
 
Upvote 0

Forum statistics

Threads
1,225,478
Messages
6,185,228
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