macro to create vbs and pass variable

clintster62

New Member
Joined
May 5, 2022
Messages
3
Office Version
  1. 2021
  2. 2016
Platform
  1. Windows
The variable to pass is EMailVar
Q: need to know how to setup vbs to receive variable

Option Explicit
' create a vbs script to receive a variable parameter and send email.
'run vbs script by passing variable
'wait for process to complete
'kill script

Sub writeVBScript()
Dim s As String
Dim SFilename As String
Dim intFileNum As Integer
Dim wshShell As Object
Dim proc As Object
Dim EMailVar As String
Dim ProcName As String
Dim VBScriptName As String

VBScriptName = "\EMailVBScript.vbs"

'write VBScript (Writes to Excel Sheet1!A1 & Calls Function Module1.ReturnVBScript)
s = ""
s = s & "Set olApp = CreateObject(""WScript.Shell"")" & vbCrLf
s = s & "olApp.Run ""outlook.exe /recycle"", 1, False" & vbCrLf
s = s & "Set CIApp = CreateObject(""Outlook.Application"")" & vbCrLf
s = s & "Set CIMessage = CIApp.CreateItem(0)" & vbCrLf
s = s & "dim EMailVar"
s = s & "With CIMessage" & vbCrLf
s = s & " .To = " & EMailVar & vbCrLf
s = s & " .Subject = ""Email test "" " & vbCrLf
s = s & " .HTMLBody = ""Message Body goes here "" " & vbCrLf
s = s & "End With" & vbCrLf
s = s & "CIMessage.Send" & vbCrLf
Debug.Print s

' Write VBScript file to disk
SFilename = ActiveWorkbook.Path & VBScriptName
intFileNum = FreeFile
Open SFilename For Output As intFileNum
Print #intFileNum, s
Close intFileNum
DoEvents

'run VBScript file and pass one variable
EMailVar = "Test_Address@gmail.com"
ProcName = "cscript " & SFilename & " " & EMailVar
Set proc = wshShell.Exec(ProcName) 'run VBScript passing variables

'Wait for script to end
Do While proc.Status = 0
DoEvents
Loop

Kill ActiveWorkbook.Path & VBScriptName
End Sub

Thanks in advance for all assistance.
 

Excel Facts

Pivot Table Drill Down
Double-click any number in a pivot table to create a new report showing all detail rows that make up that number
In the VBScript file, use CScript.Arguments(0) to get the first argument:
Code:
s = s & "EMailVar = CScript.Arguments(0)" & vbCrLf
PS - I've added the vbCrLf
 
Last edited:
Upvote 0
Still can't get it to work. Here is the create script. I have tried multiple combinations.

'write VBScript (Writes to Excel Sheet1!A1 & Calls Function Module1.ReturnVBScript)
s = ""
s = s & "Set olApp = CreateObject(""WScript.Shell"")" & vbCrLf
s = s & "olApp.Run ""outlook.exe /recycle"", 1, False" & vbCrLf
s = s & "Set CIApp = CreateObject(""Outlook.Application"")" & vbCrLf
s = s & "Set CIMessage = CIApp.CreateItem(0)" & vbCrLf
s = s & "dim EMailVar" & vbCrLf
s = s & "EMailVar = CScript.Arguments(0)" & vbCrLf
s = s & "With CIMessage" & vbCrLf
s = s & " .To = EMailVar" & vbCrLf
s = s & " .Subject = ""Excel Macro - Email test "" " & vbCrLf
s = s & " .HTMLBody = ""Message Body goes here "" " & vbCrLf
s = s & "End With" & vbCrLf
s = s & "CIMessage.Send" & vbCrLf
Debug.Print


the initiate command

' Write VBScript file to disk
SFilename = ActiveWorkbook.Path & VBScriptName
intFileNum = FreeFile
Open SFilename For Output As intFileNum
Print #intFileNum, s
Close intFileNum
DoEvents

'run VBScript file and pass one variable
EMailAddVar = "panhandlewhips@gmail.com"
ProcName = "cscript " & SFilename & " " & EMailAddVar
'MsgBox ProcName
Set wshShell = CreateObject("Wscript.Shell")
Set proc = wshShell.exec(ProcName) 'run VBScript passing variables

VBS look like this prior to kill command

Set olApp = CreateObject("WScript.Shell")
olApp.Run "outlook.exe /recycle", 1, False
Set CIApp = CreateObject("Outlook.Application")
Set CIMessage = CIApp.CreateItem(0)
dim EMailAddVar
EMailAddVar = CScript.Arguments(0)
With CIMessage
.To = EMailAddVar
.Subject = "Excel Macro - Email test "
.HTMLBody = "Message Body goes here "
End With
CIMessage.Send
 
Upvote 0
Works best to generate email from macro

Option Explicit
Sub SendEmail_Example1()

Dim i As Integer
Dim EMailAdd As String
Dim Maxrow As Integer

Maxrow = 1
'email addresses are in column 1
'loop through column 1 to determine the last row = MaxRow
Do While True
If Cells(Maxrow, 1) = "" Then
Exit Do
Else
Maxrow = Maxrow + 1
End If
Loop
Maxrow = Maxrow - 1

For i = 2 To Maxrow
Dim EmailApp As Outlook.Application
Dim Source As String
Set EmailApp = New Outlook.Application
Dim EmailItem As Outlook.MailItem
Set EmailItem = EmailApp.CreateItem(olMailItem)
EMailAdd = Cells(i, 1)
EmailItem.To = EMailAdd
If InStr(1, EMailAdd, "@") > 0 Then
'EmailItem.CC = "validemail@gmail.com"
'EmailItem.BCC = "validemail@aol.com"
EmailItem.subject = "Test Email From Excel VBA"
EmailItem.HTMLBody = "Hi," & vbNewLine & vbNewLine & "This is my first email from Excel" & _
vbCrLf & vbNewLine & _
"Regards," & vbCrLf & _
"VBA Coder: " & i
'Source = ThisWorkbook.FullName
'EmailItem.Attachments.Add Source
EmailItem.Send
End If
Next
End Sub
 
Upvote 0

Forum statistics

Threads
1,225,743
Messages
6,186,773
Members
453,370
Latest member
juliewar

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