How I send Large Power Email & Text Messages with a Batch Script

For work I have to send notifications to our Large Power customers to let them know when to shed electrical load.  The program is voluntary, so our company tells them when to shed load and then they are billed based on their demand during that time.  To make sending notifications easier, I wrote a batch file that makes use of Blat. Blat is a fantastic command line program that can be used to send emails via an exchange server (or whatever other method you like).  Check out their website for usage information.  They have lots of great examples.

I send emails by having a CSV file containing columns with First Name, Last Name, Company, Email.  I send the text messages the same way using the email to text features of the various carriers.  For example, Verizon is very popular in our area so you can send a text message by emailing your10digitnumber@vtext.com.  You can pretty easily search for other provider’s email to text formats.

The batch file does some prompting to get the proper times for control and fill in the blanks in a text message and an email.  It then just loops through the entire CSV file to get the appropriate email addresses.  I’m really only tracking First Name, Last Name and Company for my own benefit when adding or removing customers from the list.

@echo off
:: Setting Variables
set fromeMail="Your Email Name <your@email.com>"
set server=-server XXX.XXX.XXX.XXX
set debug=-debug -log "C:\Messages\blat.log" -timestamp
set SMSList=LargePowerSMS.csv
set EmailList=LargePowerEmails.csv

:: Reset the Log File
copy /y NUL "C:\Messages\blat.log" > NUL

:: Announce what script is being started!
echo This is the Large Power Text and Email Script
echo.

::Set Time Variables
set hour=%time:~0,2%
set min=%time:~3,2%
set secs=%time:~6,2%

:: Set the full name of the Day of the Week
SET MYDOW=%DATE:~0,3%
IF %MYDOW% == Mon SET FULLDOW=Monday
IF %MYDOW% == Tue SET FULLDOW=Tuesday
IF %MYDOW% == Wed SET FULLDOW=Wednesday
IF %MYDOW% == Thu SET FULLDOW=Thursday
IF %MYDOW% == Fri SET FULLDOW=Friday
IF %MYDOW% == Sat SET FULLDOW=Saturday
IF %MYDOW% == Sun SET FULLDOW=Sunday

:: Set the full name of the Month
set month=%date:~4,2%

IF %month%== 01 SET fullmonth=January
IF %month%== 02 SET fullmonth=February
IF %month%== 03 SET fullmonth=March
IF %month%== 04 SET fullmonth=April
IF %month%== 05 SET fullmonth=May
IF %month%== 06 SET fullmonth=June
IF %month%== 07 SET fullmonth=July
IF %month%== 08 SET fullmonth=August
IF %month%== 09 SET fullmonth=September
IF %month%== 10 SET fullmonth=October
IF %month%== 11 SET fullmonth=November
IF %month%== 12 SET fullmonth=December

::set the day of the month
set day=%date:~7,2%

::set the year
set year=%date:~-4%

:: Ask user if Status is Code Green or Code Red
:SetStatus
	echo Please Choose the current load control status:
	echo [1] Code Green
	echo [2] Code Red
	echo [3] Exit Program
	set /p status=Please Select 1, 2 or 3: 
	echo.
	if /i "%status:~,1%" EQU "1" goto CheckStatusInput
	if /i "%status:~,1%" EQU "2" goto CheckStatusInput
	if /i "%status:~,1%" EQU "3" goto CheckStatusInput
	echo Please Type 1, 2 or 3.
	echo.
	goto SetStatus

:CheckStatusInput
	if /i "%status:~,1%" EQU "1" echo You have chosen Code Green.
	if /i "%status:~,1%" EQU "2" echo You have chosen Code Red.
	if /i "%status:~,1%" EQU "3" echo You have chosen to exit the program.
	set /p verifystatus=Is this correct? (Y/N) 
	echo.
	if /i "%verifystatus:~,1%" EQU "Y" goto StatusVerified
	if /i "%verifystatus:~,1%" EQU "N" goto SetStatus
	echo Please Type Y or N.
	echo.
	goto CheckStatusInput
	
:StatusVerified
	if /i "%status:~,1%" EQU "1" goto CodeGreen
	if /i "%status:~,1%" EQU "2" goto CodeRed
	if /i "%status:~,1%" EQU "3" goto QuitProgram

:CodeRed
	set /p defaulttimes=Use default times of 4:00 PM to 8:00 PM? (Y/N) 
	if /i "defaulttimes:~,1%" EQU "N" goto AskTimes
	if /i "%defaulttimes:~,1%" EQU "Y" goto DefaultStartStopTime
	echo Please Type Y or N.
	echo.
	goto CodeRed
	
:DefaultStartStopTime
	set starttime=4:00 PM
	set stoptime=8:00 PM
	goto CheckTimes
	
:AskTimes
	set /p starttime=What time does control start? 
	set /p stoptime=What time does control stop? 
	echo.
	
:CheckTimes
	echo You have the start time set as %starttime%
	echo You have the stop time set as %stoptime%
	echo.
	set /p verifytimes=Is this correct? (Y/N) 
	echo.	
	if /i "%verifytimes:~,1%" EQU "Y" goto TimeVerified
	if /i "%verifytimes:~,1%" EQU "N" goto AskTimes
	echo Please Type Y or N.
	echo.
	goto CheckTimes
	
:TimeVerified

:: Create a text file containing the Code Red SMS Message

	echo Large Power Account, Please shed electrical load during the following time period: %starttime% to %stoptime% for today, %fullmonth% %day%, %year% > "C:\Messages\LPCodeRedSMS.txt"
	
	for /F "delims=, tokens=4" %%A in (%SMSList%) DO (
		"C:\Program Files\blat3217\full\blat.exe" "C:\Messages\LPCodeRedSMS.txt" -to %%A -f %fromeMail% %server% %debug%
	)

:: Set the subject of the email and the file containing the email body
	set subj=-s "Load Control Code Red for %month%/%day%/%year%, %hour%:%min%"	
	set emailbody=LPCodeRedEmail.txt

:: Create a text file for Code Red Message for today

:: empty the email file so that today's will start fresh
	
	copy /y NUL %emailbody% > NUL
	
	echo Dawson Public Power District >> %emailbody%
	echo P.O. Box 777 >> %emailbody%
	echo Lexington NE 68850 >> %emailbody%
	echo 308-324-2386 ^| Fax: 308-324-3690 ^| http://dawsonpower.com/ >> %emailbody%
	echo. >> %emailbody%
	echo TO: Large Power Load Management Account >> %emailbody%
	echo FROM: Dawson Public Power District >> %emailbody%
	echo. >> %emailbody%
	echo DATE: %FULLDOW%, %fullmonth% %day%, %year% >> %emailbody%
	echo TIME: %hour%:%min%:%secs% >> %emailbody%
	echo. >> %emailbody%
	echo Please shed electrical load during the following time period for today, %FULLDOW%, %fullmonth% %day%, %year%: >> %emailbody%
	echo. >> %emailbody%
	echo Beginning Time: %starttime% >> %emailbody%
	echo Ending Time: %stoptime% >> %emailbody%
	echo. >> %emailbody%
	echo Due to electrical peak demands, on peak billing rates will be in effect during the above listed time period. Demands established during this period may be used to determine this month’s and the next 11 month’s electric bill. Therefore, the more you can reduce electric demand, the more you can save. >> %emailbody%
	echo. >> %emailbody%
	echo If conditions change or if control is waived prior to the ending time, we will provide another message. You can also monitor the status via the internet at http://dawsonpower.com/category/large-power/ >> %emailbody%
	echo. >> %emailbody%
	echo Thank You. >> %emailbody%
	echo. >> %emailbody%
	echo. >> %emailbody%
	echo To Unsubscribe, please reply to this email. >> %emailbody%
:: End of email generation

:: Send the email	
	for /F "delims=, tokens=4" %%A in (%EmailList%) DO (
		"C:\Program Files\blat3217\full\blat.exe" "C:\Messages\LPCodeRedEmail.txt" -to %%A -f %fromeMail% %subj% %server% %debug%
	)
	
	goto QuitProgram
		
:CodeGreen
	
:: Create a text file containing the Code Green SMS Message

	echo Large Power Account, There is No Control for today, %fullmonth% %day%, %year% > "C:\Messages\LPCodeGreenSMS.txt"

::Send the SMS messages

	for /F "delims=, tokens=4" %%A in (%SMSList%) DO (
		"C:\Program Files\blat3217\full\blat.exe" "C:\Messages\LPCodeGreenSMS.txt" -to %%A -f %fromeMail% %server% %debug%
	)

:: Set the subject of the email and the file containing the email body
	set subj=-s "Load Control Code Green for %month%/%day%/%year%, %hour%:%min%"
	set emailbody=LPCodeGreenEmail.txt

:: Create a text file for Code Green Message for today

:: empty the email file so that today's will start fresh

	copy /y NUL %emailbody% > NUL

	echo Dawson Public Power District >> %emailbody%
	echo P.O. Box 777 >> %emailbody%
	echo Lexington NE 68850 >> %emailbody%
	echo 308-324-2386 ^| Fax: 308-324-3690 ^| http://dawsonpower.com/ >> %emailbody%
	echo. >> %emailbody%
	echo TO: Large Power Load Management Account >> %emailbody%
	echo FROM: Dawson Public Power District >> %emailbody%
	echo. >> %emailbody%
	echo DATE: %FULLDOW%, %fullmonth% %day%, %year% >> %emailbody%
	echo TIME: %hour%:%min%:%secs% >> %emailbody%
	echo. >> %emailbody%
	echo Dawson Power has no Control Hours for today, %FULLDOW%, %fullmonth% %day%, %year% >> %emailbody%
	echo. >> %emailbody%
	echo Due to electrical peak demands, on peak billing rates will be in effect during the above listed time period. Demands established during this period may be used to determine this month’s and the next 11 month’s electric bill. Therefore, the more you can reduce electric demand, the more you can save. >> %emailbody%
	echo. >> %emailbody%
	echo If conditions change or if control is waived prior to the ending time, we will provide another message. You can also monitor the status via the internet at http://dawsonpower.com/category/large-power/ >> %emailbody%
	echo. >> %emailbody%
	echo Thank You. >> %emailbody%
	echo. >> %emailbody%
	echo. >> %emailbody%
	echo To Unsubscribe, please reply to this email. >> %emailbody%

:: End of email generation

:: Send the email

	for /F "delims=, tokens=4" %%A in (%EmailList%) DO (
		"C:\Program Files\blat3217\full\blat.exe" "C:\Messages\LPCodeGreenEmail.txt" -to %%A -f %fromeMail% %subj% %server% %debug%
	)

:QuitProgram
	exit /b

This code will generate a text message for a “Code Green Day” (No Control) that looks like this:

Large Power Account, There is No Control for today, June 28, 2017 

It will generate a “Code Red Message” that looks like this:

CODE RED: Large Power Account, Please shed electrical load during the following time period: 4:00 PM to 8:00 PM for today, Tuesday, June 27, 2017 

It will generate an email that looks like this for “Code Green Days”:

Dawson Public Power District 
P.O. Box 777 
Lexington NE 68850 
308-324-2386 | Fax: 308-324-3690 | http://dawsonpower.com/ 
 
TO: Large Power Load Management Account 
FROM: Dawson Public Power District 
 
DATE: Wednesday, June 28, 2017 
TIME:  8:22:17 
 
Dawson Power has no Control Hours for today, Wednesday, June 28, 2017 
 
Due to electrical peak demands, on peak billing rates will be in effect during the above listed time period. Demands established during this period may be used to determine this month’s and the next 11 month’s electric bill. Therefore, the more you can reduce electric demand, the more you can save. 
 
If conditions change or if control is waived prior to the ending time, we will provide another message. You can also monitor the status via the internet at http://dawsonpower.com/category/large-power/ 
 
Thank You. 
 
 
To Unsubscribe, please reply to this email. 

It will generate an email that looks like this for “Code Red Days”:

Dawson Public Power District 
P.O. Box 777 
Lexington NE 68850 
308-324-2386 | Fax: 308-324-3690 | http://dawsonpower.com/ 
 
TO: Large Power Load Management Account 
FROM: Dawson Public Power District 
 
DATE: Tuesday, June 27, 2017 
TIME:  8:33:52 
 
Please shed electrical load during the following time period for today, Tuesday, June 27, 2017: 
 
Beginning Time: 4:00 PM 
Ending Time: 8:00 PM 
 
Due to electrical peak demands, on peak billing rates will be in effect during the above listed time period. Demands established during this period may be used to determine this month’s and the next 11 month’s electric bill. Therefore, the more you can reduce electric demand, the more you can save. 
 
If conditions change or if control is waived prior to the ending time, we will provide another message. You can also monitor the status via the internet at http://dawsonpower.com/category/large-power/ 
 
Thank You. 
 
 
To Unsubscribe, please reply to this email. 

Hopefully somebody finds this code useful out there.  I used to use a very similar batch file to generate messages for Irrigation Customers but we have since employed a developer to do a much more elegant messaging service so that customers can sign themselves up using the Dawson Power website and opt out of messages using embedded links.

If there’s something I could be doing better, I’d love to hear suggestions on this one!  For now the code seems to be working well but I’m sure there is room for improvement.

Leave a Reply

This site uses Akismet to reduce spam. Learn how your comment data is processed.