c# - 错误代码:-2147023281,消息:C# 中使用高级搜索()的“操作失败”
问题描述
背景:
我正在使用advancedSearch()过滤我的邮箱。
我正在使用上面链接中提到的过滤器:
string filterValue = "ticket";
string filter = "urn:schemas:mailheader:subject LIKE \'%" + filterValue + "%\'";
但是,当我尝试以下操作时:
DateTime startTime = new DateTime(2018, 9, 23, 16, 48, 0);
string filter = @"@SQL=(""urn:schemas:httpmail:date"" >= '" + startTime.ToString("g") + @"')";`
这会引发一个异常,“此操作失败”。错误代码:-2147023281
我还尝试过什么(但所有这些都抛出异常并且不起作用):-
Outlook.PropertyAccessor pa = folder.PropertyAccessor;
DateTime datStartUTC = pa.LocalTimeToUTC(Convert.ToDateTime("10/19/2018"));
DateTime datEndUTC = pa.LocalTimeToUTC(Convert.ToDateTime("10/26/2018").AddDays(1));
DateTime startTime = new DateTime(2018, 9, 23, 16, 48, 0);
DateTime endTime = new DateTime(2018, 9, 26, 12, 00, 0);
string filter = @"@SQL=((""urn:schemas:httpmail:datereceived"" >= '" + datStartUTC + @"' AND ""urn:schemas:httpmail:datereceived"" <='" + datEndUTC + @"' ))";
string filter = @"@SQL =((""urn:schemas:httpmail:date"" >= '" + datStartUTC + @"' AND ""urn:schemas:httpmail:date"" <='" + datEndUTC + @"' ))";
string filter = ("http://schemas.microsoft.com/mapi/proptag/0x0E060040 > /' startTime /' ");
string filter = "[Start] >= '" + startTime.ToString("g") + "' AND [End] <= '" + endTime.ToString("g") + "'";
string filter = "urn:schemas:httpmail:datereceived LIKE \'%" + pa.LocalTimeToUTC(DateTime.Now).ToString("g") + "%\'";
string filter = "urn:schemas:httpmail:datereceived LIKE \'%" + pa.LocalTimeToUTC(DateTime.Now) + "%\'";
string filter = "urn:schemas:httpmail:datereceived LIKE \'%" + (DateTime.Now - new TimeSpan(7, 0, 0, 0)).ToString("g") + "%\'";
string filter = "urn:schemas:httpmail:datereceived"" <= '" + (DateTime.Now - new TimeSpan(7, 0, 0, 0)).ToString("g") + @"');
string filter = "urn:schemas:httpmail:datereceived LIKE \'%" + startTime + "%\'";
string filter = @"@SQL=(""urn:schemas:httpmail:datereceived"" >= '" + (DateTime.Now - new TimeSpan(7, 0, 0, 0)) + @"')";
异常消息是:
操作失败
或者
出了点问题,请重试
解决方案
我在 Microsoft Docs 中发现了这个链接。就我而言,问题是一个带有单引号的文件夹,它没有被正确转义。由于该文件夹在 AdvacedSearch 方法的 Scope 属性中使用,因此引发了异常。也许它应该可以帮助您遇到代码中缺少的内容。
推荐阅读
- ansible - Ansible 主机文件解析未按预期工作
- jpa - JPA 加入 childEntity.childForeignEntity
- mysql - 当我的mysql存储过程没有找到任何结果时,我想抛出一个异常
- excel - 将 MIN/MAX 应用到数组的 LET 函数的奇怪行为
- reactjs - 布尔值不保存到状态。使用 react-redux
- flutter - 到达结果底部时如何将更多项目加载到列表中
- c# - C#如何停止RichTextBox重绘?
- javascript - 为什么这段代码会创建填充相同重复值的数组?
- python - bot 执行下一个命令而不等待消息
- excel - 查找搜索重复值并返回备用列值