How to retrieve Outlook inbox emails using R RDCOMClient?

前端 未结 2 1420
执念已碎
执念已碎 2020-12-01 06:10
library(RDCOMClient)
## create outlook object
OutApp <- COMCreate(\"Outlook.Application\")

I want to retrieve today\'s email from an Outlook fol

相关标签:
2条回答
  • 2020-12-01 06:18

    Here is some sample code I got to work by trial and error:

    library(RDCOMClient)
    
    folderName = "AUX"
    
    ## create outlook object
    OutApp <- COMCreate("Outlook.Application")
    outlookNameSpace = OutApp$GetNameSpace("MAPI")
    
    folder <- outlookNameSpace$Folders(1)$Folders(folderName)
    # Check that we got the right folder
    folder$Name(1)
    
    emails <- folder$Items
    
    # Just doing first 10, get total number with emails()$Count()
    for (i in 1:10)
    {
      subject <- emails(i)$Subject(1)
      # Replace "#78" with the text you are looking for in Email Subject line
      if (grepl("#78", subject)[1]){
        print(emails(i)$Body())
        break
      } 
    }
    

    Sorry, but I don't know why some of these COM object require parameters (like Subject(1)), but others don't (like Body()). This worked for me on Outlook 2013, but it should also work on all versions of Outlook from 2007 on.

    To get more info on the Outlook Object model I would suggest you either get Ken Slovak's Outlook 2007 book (still relevent for later versions of Outlook), or else check out my personal website, http://www.gregthatcher.com (check out the "Scripts" section -- I have been compiling these for many years.)

    0 讨论(0)
  • 2020-12-01 06:25
    folderName = "foldername"
    
    ## create outlook object
    OutApp <- COMCreate("Outlook.Application")
    outlookNameSpace = OutApp$GetNameSpace("MAPI")
    
    fld <- outlookNameSpace$GetDefaultFolder(6)
    
    # Check that we got the right folder
    fld = fld$folders(folderName)
    
    Cnt = fld$Items()$Count()
    
    emails <- fld$items
    
    df = data.frame(sno = 1:Cnt,Text = "",stringsAsFactors=FALSE)
    
    for(i in seq(Cnt)){
      d = as.data.frame(emails(i)$Body(), stringsAsFactors=FALSE)
      df$Text[i] = d[1]
      df$Sender[i] = emails(i)[['SenderName']]
      df$To[i] = emails(i)[['To']]
      df$sub[i] = emails(i)[['subject']]
    }
    
    0 讨论(0)
提交回复
热议问题