CE MAPI实例讲解 --- 如何获取Inbox里的所有消息(二)(zhuan)

本文介绍了如何通过编程方式获取邮件系统中的特定文件夹(如草稿箱、收件箱等)及其内部的消息。主要步骤包括:设置所需文件夹属性、获取文件夹EntryID并打开文件夹对象、获取文件夹内容表及设置列属性、遍历并打开每条消息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第三步:获取Folder。我们以Drafts为例。
LPSPropValue rgprops = NULL;
ULONG ulValues    = 0;
//设置我们想拿哪个Folder,详细可以查阅MSDN关于ImsgStore的介绍,在这里我将常用的几个Folder的属性值列一下:
//PR_CE_IPM_DRAFTS_ENTRYID    drafts,草稿箱
//PR_CE_IPM_INBOX_ENTRYID Inbox,收件箱
//PR_IPM_OUTBOX_ENTRYID Outbox,发件箱
//PR_IPM_SENTMAIL_ENTRYID Sentbox,这个不知道叫什么好,寄件箱?就是已经发送的消息放的box.
//PR_IPM_WASTEBASKET_ENTRYID 垃圾箱
ULONG rgTags[]    = { 1, PR_CE_IPM_DRAFTS_ENTRYID};

// 获取Folder的Entry ID,然后通过OpenEntry获得对象
pMsgStore->GetProps((LPSPropTagArray) rgTags, MAPI_UNICODE, &ulValues, &rgprops);
pMsgStore->OpenEntry(rgprops[0].Value.bin.cb, (LPENTRYID)rgprops[0].Value.bin.lpb, NULL, MAPI_MODIFY, NULL, (LPUNKNOWN*)pFolder );
MAPIFreeBuffer(rgprops);
这样,我就拿到了需要的Folder,接下来还剩下最后一件事情,就是遍历message,其实它的过程和拿Store的过程十分相似。

第四步:获取message。
LPMAPITABLE pTable = NULL;
LPSRowSet pRows = NULL;
ULONG    ulNumCols = 1;
//指定我们需要获取Entry ID属性
SizedSPropTagArray(ulNumCols, Columns) =
{
   ulNumCols,
   PR_ENTRYID  
};

pFolder->GetContentsTable(0, &pTable);
hr = pTable->SetColumns((LPSPropTagArray)&Columns, 0);
//从这些代码可以看出,和获取Message Store的方法很相似,只不过一个是从Session对象里拿,而另一个是从Folder里面拿而已。

while(SUCCEEDED(pTable->QueryRows(1, 0, &pRows)))
{
   LPMESSAGE pMsg = NULL;
   ULONG ulMesageType;
   //通过OpenEntry获取IMessage对象
   pFolder->OpenEntry( pRows->aRow[0].lpProps[0].Value.bin.cb,
      (LPENTRYID)pRows->aRow[0].lpProps[0].Value.bin.lpb,
      NULL,
      MAPI_BEST_ACCESS,
      &ulMesageType,
      (LPUNKNOWN*)&pMsg);
   //这里拿到每个IMessage对象就代表了Folder里面的每一条Message,可以通过对它的操作来获取想要的信息。
   ......
   //不需要时记的释放
   pMsg->Release();
   FreeProws(pRows);
   pRows = NULL;
}
if(pRows)
{
   FreeProws(pRows);
}
if(pTable)
{
   pTable->Release();
}

终于完工了,第一次写,不知道讲的清楚不,如有不对的地方,欢迎大家指正。

     无聊客
   2005.8.11
yzx0023@gmail.com

资源下载链接为: https://pan.quark.cn/s/d9ef5828b597 在 Excel 电子表格中,回车换行符常用于分隔文本,使数据呈现多行显示。但在某些场景下,比如数据导入其他系统或进行特定计算时,这些换行符可能会引发问题。因此,批量清除或替换 Excel 中的回车换行符就显得十分关键。 我们可以通过手动操作来替换或清除 Excel 中的回车换行符。具体操作为:打开 Excel 文件,选中包含换行符的单元格或整个工作表,点击顶部的“查找和选择”按钮,在弹出的对话框中选择“替换”选项卡。在“查找内容”栏中,按住 Alt+Enter 键输入回车换行符(在无字符显示处按一次即可),在“替换为”栏中不输入任何内容,表示将回车换行符替换为空,最后点击“全部替换”按钮,Excel 会遍历整个选区,将所有回车换行符替换为空。不过,手动操作效率较低,尤其是当文件较大或需要处理多个文件时,这种方法就不太适用了。 此时,可以借助第三方工具,例如 ReplaceExcelEnterWrap.exe。这是一个专门用于批量处理 Excel 文件中回车换行符的小型应用程序。使用步骤如下:首先,下载并解压缩 ReplaceExcelEnterWrap.exe 压缩包;接着,将包含需要处理的 Excel 文件的文件夹与 ReplaceExcelEnterWrap.exe 放在同一目录下;然后,运行 ReplaceExcelEnterWrap.exe 程序,它会自动搜索该目录下的所有 Excel 文件;程序会询问是否替换回车换行符以及是否清除空格,根据需求选择相应选项;最后,等待程序执行完毕,所有指定操作将在原文件上完成,无需手动保存。 除了 ReplaceExcelEnterWrap.exe,还可以使用其他编程语言(如 Python、VBA 等)编写脚本来实现批量处理。例如,在 Pyt
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值