- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在 StackO
的帮助下编写了这个方法,但我一直找不到改进方法。
现在,我遍历 Office 365 收件箱中的每封邮件,遍历其附件集合,并将每个文件保存到磁盘(如果它是 Excel 工作簿)。这目前有效,但会导致大量调用 Exchange。收件箱的大小可能会变得非常大,因此需要很长时间才能运行,每次调用大约需要 0.5 秒。
如果我没记错的话,调用次数的比例为 (n/100) + 2n。
注意:通常 (99.9999%) 每封邮件只有一个附件,但我为 CYA 目的添加了内部循环。可能有一些内存开销,但几乎没有比例因子。
我想知道是否有更好的方法来减少 Web 服务调用。有没有可以批量下载附件的EWS方法?我对 EWS 很陌生,所以我确定我在这里缺乏理解。 我想做的是减少 pageSize
和 Load(path)
一批文件到磁盘,减少规模。
如有任何关于减少 EWS 调用的改进以下代码的建议,我们将不胜感激。
public void SaveAttachmentsFromInbox(string[] extensionFilter = null)
{
// Default to excel files
extensionFilter = extensionFilter ?? new[] { ".xls", ".xlsx" };
// Config for traversing inbox
int offset = 0;
int pageSize = 100;
ItemView view = new ItemView(pageSize, offset, OffsetBasePoint.Beginning);
view.PropertySet = PropertySet.FirstClassProperties;
FindItemsResults<Item> findResults;
// Loop through the inbox
// and save all attachments of the designated file types
bool more = true;
var fileCount = 0;
while (more)
{
findResults = service.FindItems(WellKnownFolderName.Inbox, view);
// Load each sheet's data into an Object
foreach (var item in findResults.Items)
{
//get FirstClassProperties
item.Load(view.PropertySet);
string vendor = GetVendor(EmailMessage.Bind(service, item.Id));
messageIds.Add(item.Id.ToString());
// Save files to disk
foreach (FileAttachment file in item.Attachments)
{
string fileExtension = file.Name.Substring(file.Name.IndexOf('.'), file.Name.Length - file.Name.IndexOf('.'));
if (extensionFilter.Contains(fileExtension))
{
var fullPath = Path.Combine(path, file.Name);
attachmentInfo.Add(fullPath, vendor);
// Loads attachment and saves to disk
file.Load(fullPath);
fileCount++;
Console.Write("\rFiles received... {0} ", fileCount);
}
}
}
Console.WriteLine(); // Next line
more = findResults.MoreAvailable;
// Page through inbox if more messages remain
if (more)
{
view.Offset += pageSize;
}
}
Console.WriteLine(attachmentInfo.Count + " Excel Attachment Downloads successful.\n");
}
最佳答案
除了使用 AQS 减少从服务器返回的记录集之外,您还应该使用批处理命令首先使用 LoadPropertiesForItems(替换每个项目代码中的绑定(bind))获取项目属性,然后您可以使用 GetAttachments 批处理附件下载(您需要确保使用 EWS Managed API 的 2.2 版)这意味着例如一批 100 个项目您进行一个 FindItems 调用、一个批处理 GetItem 调用和一个批处理 GetAttachment 调用而不是 1 * 100 * 100 如果您使用绑定(bind)和加载。例如像
ItemView ivItemView = new ItemView(100);
PropertySet flLevel = new PropertySet(BasePropertySet.IdOnly);
ivItemView.PropertySet = flLevel;
FindItemsResults<Item> faItems = service.FindItems(WellKnownFolderName.Inbox, "attachment:.xlsx OR attachment:xls", ivItemView);
PropertySet slLevel = new PropertySet(BasePropertySet.FirstClassProperties);
if (faItems.Items.Count > 0)
{
service.LoadPropertiesForItems(faItems, slLevel);
}
List<Attachment> atAttachments = new List<Attachment>();
foreach (Item itItem in faItems.Items)
{
foreach (Attachment atAttachment in itItem.Attachments)
{
if (atAttachment is FileAttachment)
{
string fileExtension = atAttachment.Name.Substring(atAttachment.Name.IndexOf('.'), atAttachment.Name.Length - atAttachment.Name.IndexOf('.'));
if (extensionFilter.Contains(fileExtension))
{
atAttachments.Add(atAttachment);
}
}
}
}
service.GetAttachments(atAttachments.ToArray(), BodyType.HTML,null);
foreach (FileAttachment FileAttach in atAttachments)
{
Console.Write(FileAttach.Name);
System.IO.File.WriteAllBytes("c:\\export\\" + FileAttach.Name, FileAttach.Content);
//save off
}
关于c# - 从收件箱下载附件时如何减少 EWS 调用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33898269/
我没有上传附件以使浏览器正常工作。 一些提示是 here , 其他 there . The docs非常好,但我无法将其转换为 AJAX 上传。 我正在寻找一个 super 简单的 HTML/Java
我有一个应用程序可以收集一些信息并允许用户使用 Android 的 Intent 框架共享这些信息。 到目前为止,它以纯文本形式共享报告:使用 putExtra(Intent.EXTRA_TEXT,
我正在尝试通过我的应用程序发布带有附件图片的消息,所以我使用了以下代码: function yamPost(mytoken) { var msg_Body = jQuery("#myB
我在用户表中使用了多对多关系来使登录用户关注另一个用户,但我自己没有弄清楚,我检查了其他人做了什么,并尝试做类似的事情,并且它有效。在我的方法中,我有: function follow(User $u
我正在用 PHP 创建脚本,其作用是将 IMAP 服务器备份到 MySQL 数据库。 我现在的问题是: 如果电子邮件有附件,附件是嵌入在电子邮件本身中还是服务器上的一个单独文件? 我问的原因是: 我可
我正在使用 RavenDB,在我处理任何附件之前删除了一些带有附件的测试文档,所以我在想它们是否还在磁盘上的某个地方,以及如何轻松地找到它们?。 另一个问题是:当文档被删除时,它有一个附件,附件会被自
当您使用 ACTION_SEND Intent (使用额外的 EXTRA_STREAM)将文件附加到电子邮件时,电子邮件应用程序是否将该附加文件复制到它自己的位置?我的应用程序创建了一个文件并将其附加
所以: // Setup mail class, recipients and body $mailer->AddAttachment('/home/mywebsite/public_html/fil
您好,我需要一个 DnD 解决方案来将 Outlook 邮件附件拖到 Stackpane。 JavaFX/展望 2010 stackpaneDragAndDropZone.setOnDragO
我尝试制作一个 PhpSpreadsheet 文档,然后将他添加到邮件附件中。也许是太热了,但在 phpSpreadsheet 文档中几个小时后,我还没有找到任何东西。 这是我发送邮件的文件 $nam
有什么方法可以动画删除 UITableView 单元格附件吗? 我当前正在显示一个 UITableViewCellAccessoryDisclosureIndicator,但我想在所有可见表格单元格上
我正在编写一个 iPhone 应用程序,它要求我以编程方式发送电子邮件附件。附件是我通过代码创建的 csv 文件。然后,我将文件附加到电子邮件中,附件就会显示在手机上。但是,当我向自己发送电子邮件时,
我正在尝试通过收件箱中的名称“MacroEnabled”访问子文件夹,找到其中的所有附件并将它们保存到本地驱动器。 我使用此代码创建一个名为“Documents”的文件夹并保存附件。然而,在进行第二次
将 corda 升级到版本 4 后,我收到 net.corda.core.transactions.MissingContractAttachments:找不到 com.template.contra
我正在尝试让 Jenkins 将一个或一组文件附加到作业已完成的电子邮件通知中。我不断收到以下错误: 发送电子邮件以触发:成功错误:访问要附加的文件时出错:需要 Ant GLOB 模式,但看到 C:\
我创建了一个由来自 mysql 的数据填充的 UITableView(使用 NSJSONSERIALIZATION)。现在问题是一回事。我检索到的是产品名称。我想要一个附件 View (像单元格右侧的
我开发了一个 Java 客户端应用程序,用于下载我自己的电子邮件。我发现我无法在电子邮件中找到某些附件,特别是当我向经过认证的公司发送电子邮件时收到的作为收据的 XML 文件。我用于下载附件的代码:
我正在将我的 sqlite 数据库转换为 Couchdb。我可以转换数据库并上传到 Couchdb 服务器。除了图像之外的一切。我想将图像作为独立附件上传,我想使用 javascript、REST 和
我编写了一段代码,以便能够启动默认的电子邮件服务提供商,即我的 Outlook。这是我的代码: if(role.getValue().equals("1")) { Desktop desktop =
我正在尝试使用链接上共享的代码使用 python 从 Gmail 下载电子邮件附件 https://gist.github.com/baali/2633554 我想应用时间过滤器+主题过滤器并下载附件
我是一名优秀的程序员,十分优秀!