ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

Powershell读取Outlook并输出为PNG图片

2021-09-21 19:34:29  阅读:158  来源: 互联网

标签:Outlook Collect xlOutlook openMail source GC docPpt Powershell 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对应幻灯片中文本框的序数,具体可以手工调试得到。

标签:Outlook,Collect,xlOutlook,openMail,source,GC,docPpt,Powershell,PNG
来源: https://www.cnblogs.com/xxluna/p/15317590.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有