duanmianhong4893 2015-05-06 03:26
浏览 63
已采纳

无法在Excel中手动发送Lotus Notes电子邮件

I'm trying to use Macro to send Lotus Notes email to customers, I'm able to send it automatically, but in case there's anything I would like to add it before sending, so I want to set it as a manual mode, so that I can view the email first, and probably make some change before sending, so my question is how should I amend it? I have some ways but they are not working.

I will then post my entire code with automatic sending function:

Sub Send_Unformatted_Rangedata(i As Integer)
Dim noSession As Object, noDatabase As Object, noDocument As Object
Dim vaRecipient As Variant
Dim rnBody As Range
Dim Data As DataObject
Dim rngGen As Range
Dim rngApp As Range
Dim rngspc As Range

Dim stSubject As String
stSubject = "E-Mail For Approval for " + (Sheets("Summary").Cells(i, "A").Value) + "  for the Project  " + Replace(ActiveWorkbook.Name, ".xls", "")
'Const stMsg As String = "Data as part of the e-mail's body."
'Const stPrompt As String = "Please select the range:"

'This is one technique to send an e-mail to many recipients but for larger
'number of recipients it's more convenient to read the recipient-list from
'a range in the workbook.
vaRecipient = VBA.Array(Sheets("Summary").Cells(i, "U").Value, Sheets("Summary").Cells(i, "V").Value)

 On Error Resume Next
'Set rnBody = Application.InputBox(Prompt:=stPrompt, _
     Default:=Selection.Address, Type:=8)
 'The user canceled the operation.
'If rnBody Is Nothing Then Exit Sub
 Set rngGen = Nothing
 Set rngApp = Nothing
 Set rngspc = Nothing

 Set rngGen = Sheets("General Overview").Range("A1:C30").SpecialCells(xlCellTypeVisible)
 Set rngApp = Sheets("Application").Range("A1:E13").SpecialCells(xlCellTypeVisible)

 Set rngspc = Sheets(Sheets("Summary").Cells(i, "P").Value).Range(Sheets("Summary").Cells(i, "Q").Value).SpecialCells(xlCellTypeVisible)
 Set rngspc = Union(rngspc, Sheets(Sheets("Summary").Cells(i, "P").Value).Range(Sheets("Summary").Cells(i, "R").Value).SpecialCells(xlCellTypeVisible))

  On Error GoTo 0

  If rngGen Is Nothing And rngApp Is Nothing And rngspc Is Nothing Then
      MsgBox "The selection is not a range or the sheet is protected. " & _
           vbNewLine & "Please correct and try again.", vbOKOnly
      Exit Sub
  End If

'Instantiate Lotus Notes COM's objects.
Set noSession = CreateObject("Notes.NotesSession")
Set noDatabase = noSession.GETDATABASE("", "")

'Make sure Lotus Notes is open and available.
If noDatabase.IsOpen = False Then noDatabase.OPENMAIL

'Create the document for the e-mail.
Set noDocument = noDatabase.CreateDocument

'Copy the selected range into memory.
rngGen.Copy
rngApp.Copy
rngspc.Copy

'Retrieve the data from then copied range.
Set Data = New DataObject
Data.GetFromClipboard

'Add data to the mainproperties of the e-mail's document.
With noDocument
    .Form = "Memo"
    .SendTo = vaRecipient
    .Subject = stSubject
    'Retrieve the data from the clipboard.
    .Body = Data.GetText & " " & stMsg
    .SaveMessageOnSend = True
End With

'Send the e-mail.
With noDocument
    .PostedDate = Now()
    .send 0, vaRecipient
End With

'Release objects from memory.
Set noDocument = Nothing
Set noDatabase = Nothing
Set noSession = Nothing

'Activate Excel for the user.
'Change Microsoft Excel to Excel
AppActivate "Excel"

'Empty the clipboard.
Application.CutCopyMode = False

MsgBox "The e-mail has successfully been created and distributed.", vbInformation

End Sub

Sub Send_Formatted_Range_Data(i As Integer)
Dim oWorkSpace As Object, oUIDoc As Object
Dim rnBody As Range
Dim lnRetVal As Long
Dim stTo As String
Dim stCC As String
Dim stSubject As String
Const stMsg As String = "An e-mail has been succesfully created and saved."

Dim rngGen As Range
Dim rngApp As Range
Dim rngspc As Range

stTo = Sheets("Summary").Cells(i, "U").Value
stCC = Sheets("Summary").Cells(i, "V").Value
stSubject = "E-Mail For Approval for " + (Sheets("Summary").Cells(i, "A").Value) + "  for the Project  " + Replace(ActiveWorkbook.Name, ".xls", "")

'Check if Lotus Notes is open or not.
lnRetVal = FindWindow("NOTES", vbNullString)

If lnRetVal = 0 Then
    MsgBox "Please make sure that Lotus Notes is open!", vbExclamation
    Exit Sub
End If

Application.ScreenUpdating = False

 Set rngGen = Sheets("General Overview").Range("A1:C30").SpecialCells(xlCellTypeVisible)
 Set rngApp = Sheets("Application").Range("A1:E13").SpecialCells(xlCellTypeVisible)

 Set rngspc = Sheets(Sheets("Summary").Cells(i, "P").Value).Range(Sheets("Summary").Cells(i, "Q").Value).SpecialCells(xlCellTypeVisible)
 Set rngspc = Union(rngspc, Sheets(Sheets("Summary").Cells(i, "P").Value).Range(Sheets("Summary").Cells(i, "R").Value).SpecialCells(xlCellTypeVisible))
 On Error GoTo 0

If rngGen Is Nothing And rngApp Is Nothing And rngspc Is Nothing Then
    MsgBox "The selection is not a range or the sheet is protected. " & _
           vbNewLine & "Please correct and try again.", vbOKOnly
    Exit Sub
End If

rngGen.Copy
rngApp.Copy
rngspc.Copy

'Instantiate the Lotus Notes COM's objects.
Set oWorkSpace = CreateObject("Notes.NotesUIWorkspace")

On Error Resume Next

Set oUIDoc = oWorkSpace.ComposeDocument("", "mail\xldennis.nsf", "Memo")
On Error GoTo 0

Set oUIDoc = oWorkSpace.CurrentDocument

'Using LotusScript to create the e-mail.
Call oUIDoc.FieldSetText("EnterSendTo", stTo)
Call oUIDoc.FieldSetText("EnterCopyTo", stCC)
Call oUIDoc.FieldSetText("Subject", stSubject)

'If You experience any issues with the above three lines then replace it with:
'Call oUIDoc.FieldAppendText("EnterSendTo", stTo)
'Call oUIDoc.FieldAppendText("EnterCopyTo", stCC)
'Call oUIDoc.FieldAppendText("Subject", stSubject)

'The can be used if You want to add a message into the created document.
Call oUIDoc.FieldAppendText("Body", vbNewLine & stBody)

'Here the selected range is pasted into the body of the outgoing e-mail.
Call oUIDoc.GoToField("Body")
Call oUIDoc.Paste

'Save the created document.
Call oUIDoc.Save(True, False, False)
'If the e-mail also should be sent then add the following line.
'Call oUIDoc.Send(True)

'Release objects from memory.
Set oWorkSpace = Nothing
Set oUIDoc = Nothing

With Application
    .CutCopyMode = False
    .ScreenUpdating = True
End With

MsgBox stMsg, vbInformation

'Activate Lotus Notes.
 AppActivate ("Notes")
'Last edited Feb 11, 2015 by Peter Moncera

End Sub
  • 写回答

1条回答 默认 最新

  • doune1000 2015-05-06 05:27
    关注

    The code I have for my lotus notes to send or display is shown below, you'll need to amend it for your code. For me activecell.offset(0,11) has either 'Send' or 'Display' written in it.

    'Send the document
    If ActiveCell.Offset(0, 11).Value = "Send" Then
        MailDoc.SAVEMESSAGEONSEND = True
        MailDoc.PostedDate = Now()
        Call MailDoc.Send(0, ActiveCell.Offset(0, 7).Value)
    Else
        MailDoc.Save True, True, False
        Set uiMemo = ws.EditDocument(True, MailDoc)
    End If
    

    EDIT The above code is for if you want the option to send/display based on a parameter in your spreadsheet. For your specific issue, you will need to change this code, (it might be worth removing this code and seeing if the email displays in lotus notes):

    'Send the e-mail.
    With noDocument
        .PostedDate = Now()
        .send 0, vaRecipient
    End With
    

    If after removing the above code, running it and it doesn't display in Lotus Notes, replace the above with the below code:

    'Send the e-mail.
    Dim uiMemo As Object
    Dim ws As Object
    Set ws = CreateObject("Notes.NotesUIWorkspace")
    noDocument.Save True, True, False
    Set uiMemo = ws.EditDocument(True, noDocument)
    

    Let me know how that goes.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
  • ¥15 网络设备配置与管理这个该怎么弄
  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?