Purpose
This example demonstrates how to send an email using the mail merge features in NetMailBot. Specifically, it demonstrates how one can set the -attachment parameter to a field in a database/data file. The database used is a text file in CSV format (comma delimited file) which contains some sample data.
NOTE: You should change the email addresses in the CSV text file to your own email address(es) before running a test.
Additional Prerequisites
Windows 95 / 98 Users: Make sure you have the latest ODBC drivers installed on your machine.
Prepared Example Files
The -bodyfile parameter in NetMailBot uses full paths. We have assumed a particular path as shown in the batch file contents below. Therefore, download this file to C:\tmp on your hard drive or edit the parameters to reflect wherever you unzip the archive.
The archive contains four files:
- MailMergeCSVCustAtch.bat - The batch file that will instruct NetMailBot to send the email message.
- data.txt - The CSV file that contains the mail merge data.
- body.txt - The message body.
- stuff.txt - A file that is used as an attachment.
File Contents
This is the content of the batch file:
netmailbot -to test@exclamationsoft.com -from test@exclamationsoft.com -subject "Mail Merge Example" -server localhost -logfile c:\tmp\log.txt -dsn "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\tmp\;Extended properties=Text;" -dbquery "SELECT * FROM data.txt" -dbemailcolumn "email" -dbreplacementids "<<name>>=name,<<tracking>>=tracking,<<attachment>>=attachment" -bodyfile "c:\tmp\body.txt" -attachment "<<attachment>>" -personalize
The data file contains:
email,name,tracking,attachment
test@exclamationsoft.com,John Smith,Z9102009591871047220382,c:\tmp\body.txt
test@exclamationsoft.com,Mike White,Z9823948208740987409832,c:\tmp\stuff.txt
test@exclamationsoft.com,Tom Blue,Z2398409577583757873481,c:\tmp\body.txt
Here is the body.txt file:
Dear <<name>>,
Your tracking number is <<tracking>>
The stuff.txt file is empty.
Steps
- Unzip the MailMergeCSVCustAtch.zip file. This will produce a directory called "MailMergeCSVCustAtch". Open this directory.
- Open the data.txt file.
- Change all of the email addresses to your email address (for the purposes of this test run, they can all be the same).
- Save and close the data.txt file.
- Open Notepad and edit the batch file "MailMergeCSVCustAtch.bat". Note these important parameters used in the batch file:
- Change the parameters: -to test@exclamationsoft.com -from test@exclamationsoft.com to your own email address.
- Change the parameter: -server localhost to your own mail server.
- Note the use of -dsn "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\tmp\;Extended properties=Text;". This is a normal connection string that instructs NetMailBot on how to connect to the data.txt file. If you have not unzipped the archive to C:\tmp, you will have to edit this accordingly.
- -dbquery "SELECT * FROM data.txt" instructs NetMailBot to select all of the data from the file data.txt. This file is considered to be a pseudo database table.
- -dbemailcolumn "email" instructs NetMailBot to use the data in the "column" named "email" to address the message to the data contained in that column for the current row. This overrides the -to parameter.
- The parameter -bodyfile "C:\tmp\bodyfile.txt" instructs NetMailBot to use the contents of the file body.txt as the email message body. The replacement IDs in the body are replaced as described next.
- -dbreplacementids "<<name>>=name,<<tracking>>=tracking,<<attachment>>=attachment" instructs NetMailBot to replace the strings in double-angle brackets with the data contained in the mapped column for the current row. For example, in the message body, NetMailBot will replace the string <<name>> with the data contained in the column named "name".
- -attachment "<<attachment>>" instructs NetMailBot to attach a file based on the data contained in the column mapped to <<attachment>>, which happens to be "attachment".
- -personalize instructs NetMailBot to make the replacements. Without this parameter specified, NetMailBot will not perform any replacements.
- Invoke the batch file by double-clicking the icon or straight from the command line.
- NetMailbot should start up and, upon finishing, the email addresses specified indirectly via the -dbemailcolumn parameter should each receive a personalized text message with attachments dynamically added based on the data in the data file.