10

我每周日都会收到一封带有附件(压缩文件夹)的电子邮件。电子邮件的主题永远不会改变。我想查找具有指定主题行的最新电子邮件并下载附件。我是新的 R 用户,到目前为止,我只找到了一种基于主题打印电子邮件正文的方法(来自 stackoverflow如何使用 R RDCOMClient 检索 Outlook 收件箱电子邮件?)。理想情况下,我想找到在指定日期收到的具有指定主题的电子邮件,然后下载附件。有人可以指出我正确的方向。任何帮助将不胜感激。谢谢你。

4

2 回答 2

18

您可以使用 AdvancedSearch 方法搜索您的收件箱或任何其他文件夹:

library(RDCOMClient)
outlook_app <- COMCreate("Outlook.Application")
search <- outlook_app$AdvancedSearch(
    "Inbox",
    "urn:schemas:httpmail:subject = 'Super Important Email'"
)

这是一种异步方法,因此 R 在继续下一步之前不会等待搜索完成。虽然确实存在AdvancedSearchComplete处理此问题的事件,但我无法弄清楚如何使用 RDCOMClient 执行此操作。作为一种解决方法, aSys.sleep(5)应该给搜索足够的时间来完成。

您可以查看这些结果并使用该方法查询它们的接收时间ReceivedTime。要将这些时间转换为日期,请使用 1899 年 12 月 30 日的 Microsoft Office 基准日期:

results <- search$Results()
results$Item(1)$ReceivedTime() # Received time of first search result
as.Date("1899-12-30") + floor(results$Item(1)$ReceivedTime()) # Received date

我们现在可以查看在特定日期(例如 2017 年 8 月 14 日)收到的电子邮件的结果。

for (i in 1:results$Count()) {
    if (as.Date("1899-12-30") + floor(results$Item(i)$ReceivedTime()) 
            == as.Date("2017-08-14")) {
        email <- results$Item(i)
    }
}

我们可以像查看搜索结果一样查看电子邮件的附件。第一个附件将是email$Attachments(1)(注意电子邮件签名中的图片;这些也会出现!)。如果您对某个特定附件感兴趣,可以使用该FileName方法找到它。找到所需的附件后,您可以将其保存到文件中并像使用其他文件一样开始使用它。

attachment_file <- tempfile()
email$Attachments(1)$SaveAsFile(attachment_file)
data <- read.csv(attachment_file)

我在这里使用了临时文件路径,但您当然可以将附件保存到永久位置。

于 2017-08-14T00:13:01.830 回答
0

在阅读了mdneuzerling的精彩原始解决方案中的评论后,我想添加一个额外的答案,其中包含一个如何从子文件夹中提取数据的示例。这是我最近才发现的,并且从原始解决方案中借鉴了很多。

假设您的主要电子邮件是 user@outlook.com,并且在该地址中有一个名为“收件箱”的文件夹。此外,假设您的收件箱中有一个名为“重要”的子文件夹。如果您想从标题为“带附件的电子邮件”的电子邮件中从该子文件夹下载附件,您可以按如下方式定义文件路径:

path <- outlookNameSpace$Folders("user@outlook.com")$Folders("Inbox")$Folders("Important")$FolderPath()

然后,您将通过以下代码使用mdneuzerling 的答案中指定的 AdvancedSearch 方法:

   search <- outlook_app$AdvancedSearch(
             paste0("'", path, "'"),
             "urn:schemas:httpmail:subject = 'Email with Attachment'"
)

通过遵循mdneuzerling解决方案中概述的其余方法,您应该能够从子文件夹中提取附件。

于 2021-03-30T13:39:43.077 回答