标签:Outlook Collect xlOutlook openMail source GC docPpt Powershell PNG
前言
工作上定时汇总服务器状态的脚本,会读取服务器状态后发送到指定的服务器。原始的统计数据比较混乱,需要提取出部分数据汇总后,再将邮件全文进行截图,比较繁琐。 故通过脚本来处理并生成截图。
原理
- 首先通过COM接口读取当前打开的邮件正文内容(body)并传入脚本内;
- 然后通过正则表达式对原始数据进行匹配
- 最后通过COM接口打开PPT文件,传入原始数据,并另存为PNG图片。
代码部分
try {
$xlOutlook = New-Object -ComObject Outlook.Application;
$openMail = $xlOutlook.Inspectors[1].CurrentItem; }
catch {
Write-Host "Outlook邮件打开失败,错误原因:"$Error[0];$xlOutlook = $null;pause;[GC]::Collect();
exit(-1)
}
$date = $openMail.ReceivedTime;
$source=$openMail.Body;
$xlOutlook = $null;$openMail = $null;[GC]::Collect();
(业务逻辑代码 略)
$objPpt=New-Object -ComObject Powerpoint.application
$docPpt=$objPpt.Presentations.open('D:\temp.pptx')
$docPpt.Slides(1).shapes(2).TextFrame.TextRange.Text=$source
$docPpt.SaveAs("d:\today",18)
$docPpt.Close()
$objPpt.Quit()
[GC]::Collect()
注
- PPT文件需要预先定义好文本框格式,以确保输入的正文内容能恰好填充满文本框且具备可读性;
- 对于
$docPpt.Slides(1).shapes(2).TextFrame.TextRange.Text=$source
,Slide对应幻灯片的页数,Shape对应幻灯片中文本框的序数,具体可以手工调试得到。
标签:Outlook,Collect,xlOutlook,openMail,source,GC,docPpt,Powershell,PNG 来源: https://www.cnblogs.com/xxluna/p/15317590.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。