Email from excel via Lotus Notes

gaz_chops

Well-known Member
Joined
Apr 29, 2003
Messages
6,485
Platform
  1. MacOS
I managed to find this piece of code on this site, which I thought (hoped) I might be able to adapt, one huge problem is that I have never used vb???
What I need to do is send an email to each of the house no.s (as per the excel example, but without the leading alpha character) and populate the ????in the vb with the "Model/Item"......any help would be hugely welcome

Thanks
Gaz

Sub SendNotesMail()
Dim Maildb As Object, UserName As String, MailDbName As String
Dim MailDoc As Object, Session As Object
Set Session = CreateObject("Notes.NotesSession")
UserName = Session.UserName
MailDbName = Left$(UserName, 1) & Right$(UserName, _
(Len(UserName) - InStr(1, UserName, " "))) & ".nsf"
Set Maildb = Session.GetDatabase("", MailDbName)
If Maildb.IsOpen = True Then
Else: Maildb.OpenMail
End If
Set MailDoc = Maildb.CreateDocument
MailDoc.Form = "Memo"
MailDoc.SendTo = "0504" 'Nickname or full address
'MailDoc.CopyTo = 'whomever
'MailDoc.BlindCopyTo = Whomever
MailDoc.Subject = "Machine Change"
MailDoc.Body = _
Replace("As a result of a review of your AWP collections that I have carried out,@@I have asked Leisure Link to replace your ????? AWP.@@@@I or your Leisure Link Business Account Manager will try @@to phone you to discuss this within the next couple of days.@@However if you have any immediate comments,@@please do not hesitate to contact either of us." _
& Join(Application.Transpose(Range([b5], [b65536].End(3))), "@") _
& "@@With kind regards", "@", vbCrLf)
MailDoc.SaveMessageOnSend = True
MailDoc.PostedDate = Now
On Error GoTo Audi
Call MailDoc.Send(False)
Set Maildb = Nothing: Set MailDoc = Nothing: Set Session = Nothing
Exit Sub
Audi:
Set Maildb = Nothing: Set MailDoc = Nothing: Set Session = Nothing
End Sub
PCIMIS Notes.xls
ABCD
1HseNo'Model/ItemRecommendation
2C050425NOTERUNNERchangetoJacktheKipper
3C322325ROYALROULETTEANBdropping-changetoSuperstars/TopDog/HiFlyer
4C122825HYPNOTICChangeHypnotic-urgent
5S556425TOPDOGChangetoBubble&Squeak/Jackpot&Beanstreak Changestilloutstanding
6S556425CASHEXPLOSIONnoedcsinceinstall-pleasecheck.Stillnoedcbeingreceivedpleasedealwith ChangetoMonopoly/Dambusters changestilloutstanding
7S556425DO$HNPECKSChangeQualityStreak/Superstars/Dambuster
8C325325CASHBANGWALLOPChangetoJumpinJokersorcashExplosionon82%
9S913525JACKPOTANDTHEBEANSTREAKChangeANBdropping-injectionplease
Sheet1
 

Excel Facts

How to find 2nd largest value in a column?
MAX finds the largest value. =LARGE(A:A,2) will find the second largest. =SMALL(A:A,3) will find the third smallest
Looks like something I might have posted... Which columns are you sending? This is looking at column B...

Try the following:

Code:
Sub SendNotesMail()
Dim Maildb As Object, UserName As String, MailDbName As String
Dim MailDoc As Object, Session As Object
Dim myArr As Variant, i As Long
Set Session = CreateObject("Notes.NotesSession")
UserName = Session.UserName
MailDbName = Left$(UserName, 1) & Right$(UserName, _
    (Len(UserName) - InStr(1, UserName, " "))) & ".nsf"
Set Maildb = Session.GetDatabase("", MailDbName)
If Maildb.IsOpen = True Then
    Else: Maildb.OpenMail
End If
Set MailDoc = Maildb.CreateDocument
MailDoc.Form = "Memo"
MailDoc.SendTo = "0504" 'Nickname or full address
'MailDoc.CopyTo = Whomever
'MailDoc.BlindCopyTo = Whomever
MailDoc.Subject = "Machine Change"
myArr = Range([a2], [a65536].End(3))
For i = LBound(myArr) To UBound(myArr)
    myArr(i) = Right(myArr(i), Len(myArr(i)) - 1)
Next
MailDoc.Body = _
    Replace("As a result of a review of your AWP collections that" & _
        "I have carried out,@@I have asked Leisure Link to replace your ????? " & _
        "AWP.@@@@I or your Leisure Link Business Account Manager will try" & _
        "@@to phone you to discuss this within the next couple of days." & _
        "@@However if you have any immediate comments,@@please do not " & _
        "hesitate to contact either of us." & _
        Join(Application.Transpose(myArr), "@") & _
        "@@With kind regards", "@", vbCrLf)
MailDoc.SaveMessageOnSend = True
MailDoc.PostedDate = Now
On Error GoTo Audi
Call MailDoc.Send(False)
Set Maildb = Nothing:    Set MailDoc = Nothing:    Set Session = Nothing
Exit Sub
Audi:
Set Maildb = Nothing:    Set MailDoc = Nothing:    Set Session = Nothing
End Sub

This is untested.
 
Upvote 0
Nate,
Thanks for your response, i'm on a course for a couple of days so won't be able to look at till the weekend.
Thanks again.

Gaz
 
Upvote 0
gaz_chops said:
Thanks for your response, i'm on a course for a couple of days so won't be able to look at till the weekend.

It's too cold to golf in Minneapolis right now, I envy you. :)

You are welcome. :)
 
Upvote 0
If only?!? Unfortunately it was a course on Performance Development Reviews not a Golf course?

Gaz
I'll post back later when I have tried the code you posted.
 
Upvote 0
Nate,
What I am after is a seperate email to each of the House No.s in column A (minus the leading alpha character), each email will then contain the Name of the Model/Item that appears next to it in column B within the text

"As a result of a review of your AWP collections that" & _
"I have carried out,@@I have asked Leisure Link to replace your £25 NOTE RUNNER " & _
"AWP.@@@@I or your Leisure Link Business Account Manager will try" & _
"@@to phone you to discuss this within the next couple of days." & _
"@@However if you have any immediate comments,@@please do not " & _
"hesitate to contact either of us." & _
Join(Application.Transpose(myArr), "@") & _

to House 0504
ps with the code you posted I keep getting a pop up message at the point :-

myArr(i) = Right(myArr(i), Len(myArr(i)) - 1)
Next

Run time error '9'
Subscript out of range

Rgaerds
Gaz
 
Upvote 0
Hello, I can't speak to your error based on your post.

Try:

<font face=Courier New><SPAN style="color:darkblue">Sub</SPAN> SendNotesMail()
<SPAN style="color:darkblue">Dim</SPAN> Maildb <SPAN style="color:darkblue">As</SPAN> <SPAN style="color:darkblue">Object</SPAN>, UserName <SPAN style="color:darkblue">As</SPAN> <SPAN style="color:darkblue">String</SPAN>, MailDbName <SPAN style="color:darkblue">As</SPAN> <SPAN style="color:darkblue">String</SPAN>
<SPAN style="color:darkblue">Dim</SPAN> MailDoc <SPAN style="color:darkblue">As</SPAN> <SPAN style="color:darkblue">Object</SPAN>, Session <SPAN style="color:darkblue">As</SPAN> <SPAN style="color:darkblue">Object</SPAN>
<SPAN style="color:darkblue">Dim</SPAN> cl <SPAN style="color:darkblue">As</SPAN> Range
<SPAN style="color:darkblue">Set</SPAN> Session = CreateObject("Notes.NotesSession")
UserName = Session.UserName
MailDbName = Left$(UserName, 1) & Right$(UserName, _
    (Len(UserName) - InStr(1, UserName, " "))) & ".nsf"
<SPAN style="color:darkblue">Set</SPAN> Maildb = Session.GetDatabase("", MailDbName)
<SPAN style="color:darkblue">If</SPAN> <SPAN style="color:darkblue">Not</SPAN> Maildb.IsOpen <SPAN style="color:darkblue">Then</SPAN> Maildb.OpenMail
<SPAN style="color:darkblue">For</SPAN> <SPAN style="color:darkblue">Each</SPAN> cl <SPAN style="color:darkblue">In</SPAN> Range([a2], [a65536].End(3))
    <SPAN style="color:darkblue">Set</SPAN> MailDoc = Maildb.CreateDocument
    MailDoc.Form = "Memo"
    MailDoc.SendTo = Right$(cl, Len(cl) - 1) <SPAN style="color:green">'Nickname or full address</SPAN>
    <SPAN style="color:green">'MailDoc.CopyTo = Whomever</SPAN>
    <SPAN style="color:green">'MailDoc.BlindCopyTo = Whomever</SPAN>
    MailDoc.Subject = "Machine Change"
    MailDoc.Body = _
        Replace("As a result of a review of your AWP collections that" & _
            "I have carried out,@@I have asked Leisure Link to replace your ????? " & _
            "AWP.@@@@I or your Leisure Link Business Account Manager will try" & _
            "@@to phone you to discuss this within the next couple of days." & _
            "@@However if you have any immediate comments,@@please do not " & _
            "hesitate to contact either of us." & _
            cl(, 2) & vbNewLine & cl(, 3) & _
            "@@With kind regards", "@", vbCrLf)
    MailDoc.SaveMessageOnSend = <SPAN style="color:darkblue">True</SPAN>
    MailDoc.PostedDate = Now
    <SPAN style="color:darkblue">On</SPAN> <SPAN style="color:darkblue">Error</SPAN> <SPAN style="color:darkblue">GoTo</SPAN> Audi
    <SPAN style="color:darkblue">Call</SPAN> MailDoc.Send(False)
Audi: <SPAN style="color:darkblue">On</SPAN> <SPAN style="color:darkblue">Error</SPAN> <SPAN style="color:darkblue">GoTo</SPAN> 0
<SPAN style="color:darkblue">Next</SPAN>
Session.Quit
<SPAN style="color:darkblue">Set</SPAN> Maildb = Nothing:    <SPAN style="color:darkblue">Set</SPAN> MailDoc = Nothing:    <SPAN style="color:darkblue">Set</SPAN> Session = <SPAN style="color:darkblue">Nothing</SPAN>
<SPAN style="color:darkblue">End</SPAN> <SPAN style="color:darkblue">Sub</SPAN></FONT>

I have not tested this for a variety of reasons.
 
Upvote 0
Nate,
Changed the code slightly to put the Model/Item in a diff place, it generates all of the emails but does not populate the mail to with the House No. in Col A?

Sub SendNotesMail()
Dim Maildb As Object, UserName As String, MailDbName As String
Dim MailDoc As Object, Session As Object
Dim cl As Range
Set Session = CreateObject("Notes.NotesSession")
UserName = Session.UserName
MailDbName = Left$(UserName, 1) & Right$(UserName, _
(Len(UserName) - InStr(1, UserName, " "))) & ".nsf"
Set Maildb = Session.GetDatabase("", MailDbName)
If Not Maildb.IsOpen Then Maildb.OpenMail
For Each cl In Range([a2], [a65536].End(3))
Set MailDoc = Maildb.CreateDocument
MailDoc.Form = "Memo"
MailDoc.SendTo = Right$(cl, Len(cl) - 1) 'Nickname or full address
'MailDoc.CopyTo = Whomever
'MailDoc.BlindCopyTo = Whomever
MailDoc.Subject = "Machine Change"
MailDoc.Body = _
Replace("As a result of a review of your AWP collections that" & _
"I have carried out,@@I have asked Leisure Link to replace your " & _
cl(, 2) & _
" AWP.@@@@I or your Leisure Link Business Account Manager will try" & _
"@@to phone you to discuss this within the next couple of days." & _
"@@However if you have any immediate comments,@@please do not " & _
"hesitate to contact either of us." & _
"@@With kind regards", "@", vbCrLf)
MailDoc.SaveMessageOnSend = True
MailDoc.PostedDate = Now
On Error GoTo Audi
Call MailDoc.Send(False)
Audi: On Error GoTo 0
Next
Session.Quit
Set Maildb = Nothing: Set MailDoc = Nothing: Set Session = Nothing
End Sub

Thanks
Gaz
 
Upvote 0
Nate,
Thanks a million it works like a dream. It did post to the house number, what I didn't realise is that we add the word "unit" after the number as the email address.

Again thanks
Gaz
 
Upvote 0
Yep, just concatenate the word unit to results of the right(cl...) function in the MailDoc.SendTo line.

You are welcome. :)
 
Upvote 0

Forum statistics

Threads
1,224,616
Messages
6,179,912
Members
452,949
Latest member
beartooth91

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top