Powershell读取Outlook并输出为PNG图片

前言

工作上定时汇总服务器状态的脚本,会读取服务器状态后发送到指定的服务器。原始的统计数据比较混乱,需要提取出部分数据汇总后,再将邮件全文进行截图,比较繁琐。 故通过脚本来处理并生成截图。

原理

  1. 首先通过COM接口读取当前打开的邮件正文内容(body)并传入脚本内;
  2. 然后通过正则表达式对原始数据进行匹配
  3. 最后通过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()

  1. PPT文件需要预先定义好文本框格式,以确保输入的正文内容能恰好填充满文本框且具备可读性;
  2. 对于$docPpt.Slides(1).shapes(2).TextFrame.TextRange.Text=$source,Slide对应幻灯片的页数,Shape对应幻灯片中文本框的序数,具体可以手工调试得到。
上一篇:Google插件开发——-这是一个能撩妹的插件(web)


下一篇:python plt文件保存为png图片