VBA Outlook邮件正文

问题描述 投票:0回答:1

在VBA脚本中,我正在尝试编写具有以下签名的子函数

Sub(taskName As String , myGroup As String, myFile As String ,myPer As String, RelatedTasks() As String    )

 Dim olApp As Outlook.Application
 Dim m As Outlook.MailItem

 Set olApp = New Outlook.Application
 Set m = olApp.CreateItem(olMailItem)

 With m
   .display
   .To = "[email protected]"
   .Subject = "Test Events"
   .HTMLBody/.body = ...    
End Sub

电子邮件正文如下:

大家好,

请查找以下信息。

任务:taskName

相关任务:RelatedTasks()

文件:myFile

PERSON:myPer

在Sub函数中,冒号左侧的模式始终是常量。右侧将根据函数的输入进行更改。

为此,我正在阅读包含所需签名的Template.htm。

Template.html包含:

Hello All,

Please find the following information.

TASK: {{mytask}}

RELATED TASK:{{myRelatedTasks}}

FILE : {{myFile}}

PERSON : {{myPerson}}

在VBA代码中,我将替换所有字段。

我面临的问题是{{mytask}}和{{related tasks}}也应该有HTML参考。我已经成功添加了mytask的链接。点击邮件中的mytask将跳转到相应的weblink。

<a href = "www.something.com&amp;id ={{taskID}}>
{{mytask}}.....<a href = "www.xxx.com&amp;id={{}}>{{myRelatedTasks}}

但由于它是一个数组,因此无法将相同的任务添加到相关任务中。

我的VBA代码:

Option Explicit

Sub CreateNewMail()

 Dim olApp As Outlook.Application
 Dim m As Outlook.MailItem
 Dim sigPath As String, sigText As String
 Dim fso As Scripting.FileSystemObject
 Dim ts As Scripting.TextStream

 Dim t As String
 Dim r(5) As Variant

 t = "233444:dshfjhdjfdhjfhjdhfjdhfjd"


 r(0) = "122343:dsjdhfjhfjdh"
 r(1) = "323243:jfjfghfjhjddj"
 r(2) = "834783:gffghjkjkgjkj"

 Set olApp = New Outlook.Application
 Set m = olApp.CreateItem(olMailItem)

 sigPath = "C:\Users\Pavan-Kumar\Desktop\vbs\TestEvents.htm"

 Set fso = New Scripting.FileSystemObject
 Set ts = fso.OpenTextFile(sigPath)

 sigText = ts.ReadAll

 ts.Close

 Set fso = Nothing

 sigText = Replace(sigText, "{{mytask}}", t)
 sigText = Replace(sigText, "{{myRelatedTasks}}", Join(r, "<br>"))

 With m
   .display
   .To = "[email protected]"
   .Subject = "Test Events"
   .HTMLBody = sigText

 End With 
End Sub

而且当我加入相关任务时,我希望他们在缩进之下来到另一个下面。我尝试将“\ t”作为分隔符并没有成功。

我在outlook邮件中的当前O / P:

enter image description here

vba outlook outlook-vba
1个回答
0
投票

以下是我为解决同一问题所做的工作:

  1. 写一封完全符合您想要的格式的电子邮件
  2. 在电子邮件中,使用字段中唯一的内容,例如{{recipient name}}
  3. 将电子邮件另存为HTML。现在这是电子邮件正文的模板。您可以为不同的情况保留几个不同的模板。
  4. 在VBA中,打开相应的模板文件并将整个内容读入字符串。
  5. 使用VBA命令Replace,填写您的字段。例如strHTMLTemplate = Replace(strHTMLTemplate, "{{recipient name}}", "Jane Doe")
  6. 将最终字符串分配给.htmlBody

对于RelatedTasks,看起来你只想让它们在一行上。在这种情况下,只需在模板中创建一个“字段”,{{RelatedTasks}},然后像strHTMLTemplate = Replace(strHTMLTemplate, "{{RelatedTasks}}", Join(RelatedTasks, ", "))那样进行替换。

如果你想获得幻想,你可以编写将字符串数组转换为html liststables的函数

© www.soinside.com 2019 - 2024. All rights reserved.