这是我的情况。 我已经制作了一个应用程序Windows窗体,它根据用户的操作编辑Excel工作表(按钮/切换/文本框等等。)。
编辑完成后,将生成新的Excel文件。
我的程序然后选择一系列单元格并复制它。 它转到剪贴板。
我已经完成了多项测试(if(){} else {} /保存到.jpg /等等。)并且所有内容都被检查为真。
我不想要附上我的照片。 我不想保存它,即使是暂时的,然后通过保存的.jpg文件将其粘贴到正文中。 我只是"想要将Ctrl + V放入我的Outlook电子邮件正文中。
这里是我如何从剪贴板中获取图像(" MessageBody"在顶部被声明为公共字符串,以便我可以通过不同的区域调用它):
public void ReadData()
{
Excel excel = new Excel(@"E:\c#\Project#XX\Resources\TEST.xlsx", 1);
excel.CopyRange(0, 0, 32, 12);
IDataObject iData = Clipboard.GetDataObject();
if (iData.GetDataPresent(DataFormats.Bitmap))
{
Bitmap MessageBody = (iData.GetData(DataFormats.Bitmap, true) as Bitmap);
//pbx.Image = Image;
//image.Save(@"E:\c#\Project#XX\Resources\bitmap1.jpg", System.Drawing.Imaging.ImageFormat.Jpeg);
//MessageBody = image;
}
excel.Close();
excel.Quit();
}
这是构建代码的消息:
private void flatCustButton013_Click(object sender, EventArgs e)
{
ReadData();
string MessageSubject = $"SomeSubject";
Outlook.MailItem newMail = (Outlook.MailItem)application.CreateItem(Outlook.OlItemType.olMailItem);
newMail.Subject = MessageSubject;
newMail.BodyFormat = Outlook.OlBodyFormat.olFormatHTML;
MessageHTMLBody = "<html><body>SomeText.<img src="cid:MessageBody"</img></body></html>";
newMail.HTMLBody = MessageHTMLBody;
//newMail.Body = System.Windows.Input.ApplicationCommands.Paste;
//newMail.Display(false);
//newMail.BodyFormat = Outlook.OlBodyFormat.olFormatHTML; ;
//newMail.HTMLBody = System.Windows.Input.ApplicationCommands.Paste;
//newMail.Body = MessageBody;
newMail.To = ToAddress;
newMail.SentOnBehalfOfName = FromAddress;
newMail.CC = CcAddress;
newMail.BCC = BccAddress;
//System.Windows.Input.ApplicationCommands.Paste;
//wrdEdit = application._Inspector.WordEditor
newMail.Send();
}
在之前的版本中,人们必须打开Excel文件,手动更改单元格,然后单击按钮(在VB中使用宏)。 它会打开一个Outlook eMail项目(显示:true),其中已经粘贴了图像,然后只需要点击&#34;发送&#34;没关系。
我的2.0版本只需点击一个&#34;发送//生成的Excel表格//&#34;按钮即可自动生成。
这是VB中的宏代码:
Sub SendMail()
Dim Messager As New Outlook.Application
Dim Mail As Outlook.MailItem
Dim WrdEdit
Range("my_range").CopyPicture
Set Messager = New Outlook.Application
Set Mail = Messager.CreateItem(olMailItem)
With Mail
.To = "some folks"
.CC = "some folks"
'.BCC = ""
.Subject = "SomeSubject"
.Display
.HTMLBody = Mess + .HTMLBody
End With
Set WrdEdit = Messager.ActiveInspector.WordEditor
WrdEdit.Application.Selection.Paste
Set WrdEdit = Nothing
Set Messager = Nothing
Set Mail = Nothing
ActiveWorkbook.Close SaveChanges:=False
End Sub
但是,如果我成功检索到剪贴板图像,我不知道为什么我会通过检查员(我不知道)。
答案 0 :(得分:0)
我找到了一种方法,将本地保存文件中的附件添加到邮件中,并使用HTML将其显示在正文中。
像这样:
newMail.BodyFormat = Outlook.OlBodyFormat.olFormatHTML;
Outlook.Attachment attachment = newMail.Attachments.Add(@"path.imageformat", Outlook.OlAttachmentType.olEmbeddeditem, null, $"someTitle");
string imagecid = "whatever";
attachment.PropertyAccessor.SetProperty("http://schemas.microsoft.com/mapi/proptag/0x3613041E", imagecid);
newMail.HTMLBody = String.Format("<body><img src=\"cid:{0}\"></body>", imageCid);
“http://schemas.microsoft.com/mapi/proptag/0x3712001E”代码在此处:http://www.outlookcode.com/codedetail.aspx?id=1915。
它有效。
但是,我真的不喜欢在我的代码中使用网址,还有其他方法吗?
而且,看起来我放入“imagecid”字符串中的任何内容都没有任何变化。
我正在努力理解我对代码的所作所为,而不仅仅是让它按原样运行。
看起来我需要Office的一些授权来处理应用程序?尤其是当我想将图像粘贴到一个正文中时(可以包含除像素数据之外的其他内容)。
如果我不需要使用VB脚本进行自动化,我想,这是因为我必须“物理/人性化”按下Outlook中的“发送邮件”按钮?
还有其他可能吗?我仍然使用文件粘贴在我的身体,我不能只是以编程方式按Ctrl + C Ctrl + V? :(