Hello Everyone,
I could really use your help; I have been working on this for a couple of weeks and have been stuck. First off I am on a Windows 7 machine 64 bit and am trying to accomplish the following:
>Open up excel file from network drive....then update all (roughly 29) Sql queries in the workbook.
>Save the workbook as ("NewDashboard 1/2/2012.xlsx) with the date in short format
>and email it to the necessary people within the company
>I have gotten it to work with the _DateTimeFormat however it doesnt seem to want to output in the short format and I have checked my regional settings and all of that however no luck. When I change the $type from a 1 (which is the only thing that currently works to a 2 for short format it gives me an error stating," The requested action with this object has failed."
Here is my code: Please please help me out guys!
I could really use your help; I have been working on this for a couple of weeks and have been stuck. First off I am on a Windows 7 machine 64 bit and am trying to accomplish the following:
>Open up excel file from network drive....then update all (roughly 29) Sql queries in the workbook.
>Save the workbook as ("NewDashboard 1/2/2012.xlsx) with the date in short format
>and email it to the necessary people within the company
>I have gotten it to work with the _DateTimeFormat however it doesnt seem to want to output in the short format and I have checked my regional settings and all of that however no luck. When I change the $type from a 1 (which is the only thing that currently works to a 2 for short format it gives me an error stating," The requested action with this object has failed."
Here is my code: Please please help me out guys!
#Include<file.au3>
#include <Excel.au3>
#include <date.au3>
_DateTimeFormat("YYYY/MM/DD",1)
$oExcel = _ExcelBookOpen("C:\Users\gpreston.corporate\Desktop\Luminance Dashboard.xlsx");open desired excel file containing macro
$oExcel.ActiveWorkbook.RefreshAll
sleep (65000)
$oExcel.ActiveWorkbook.SaveAs ("C:\Users\gpreston.corporate\Desktop\New Dashboard " & _DateTimeFormat(_NowCalc(), 1)) & ".xlsx")
$oExcel.Application.Quit
$sfile = ("C:\Users\gpreston.corporate\Desktop\New Dashboard " & _DateTimeFormat(_NowCalc(), 1) & ".xlsx")
$SmtpServer = "uslaxmail02.corp.lamparts.com" ; address for the smtp-server to use - REQUIRED
$FromName = "M.I.S" ; name from who the email was sent
$FromAddress = "mis@lamparts.com" ; address from where the mail should come
$ToAddress = "gpreston@luminance.us.com" ; destination address of the email - REQUIRED
$Subject = "Luminance Dashboard" ; subject from the email - can be anything you want it to be
$Body = "" ; the messagebody from the mail - can be left blank but then you get a blank mail
$AttachFiles = ($sfile) ; the file(s) you want to attach seperated with a ; (Semicolon) - leave blank if not needed
$CcAddress = "" ; address for cc - leave blank if not needed
$BccAddress = "" ; address for bcc - leave blank if not needed
$Importance = "Normal" ; Send message priority: "High", "Normal", "Low"
$Username = "" ; username for the account used from where the mail gets sent - REQUIRED
$Password = "" ; password for the account used from where the mail gets sent - REQUIRED
$IPPort = 25 ; port used for sending the mail
$ssl = 0 ; enables/disables secure socket layer sending - put to 1 if using httpS
Global $oMyRet[2]
Global $oMyError = ObjEvent("AutoIt.Error", "MyErrFunc")
$rc = _INetSmtpMailCom($SmtpServer, $FromName, $FromAddress, $ToAddress, $Subject, $Body, $AttachFiles, $CcAddress, $BccAddress, $Importance, $Username, $Password, $IPPort, $ssl)
If @error Then
MsgBox(0, "Error sending message", "Error code:" & @error & " Description:" & $rc)
EndIf
;
; The UDF
Func _INetSmtpMailCom($s_SmtpServer, $s_FromName, $s_FromAddress, $s_ToAddress, $s_Subject = "", $as_Body = "", $s_AttachFiles = "", $s_CcAddress = "", $s_BccAddress = "", $s_Importance="Normal", $s_Username = "", $s_Password = "", $IPPort = 25, $ssl = 0)
Local $objEmail = ObjCreate("CDO.Message")
$objEmail.From = '"' & $s_FromName & '" <' & $s_FromAddress & '>'
$objEmail.To = $s_ToAddress
Local $i_Error = 0
Local $i_Error_desciption = ""
If $s_CcAddress <> "" Then $objEmail.Cc = $s_CcAddress
If $s_BccAddress <> "" Then $objEmail.Bcc = $s_BccAddress
$objEmail.Subject = $s_Subject
If StringInStr($as_Body, "<") And StringInStr($as_Body, ">") Then
$objEmail.HTMLBody = $as_Body
Else
$objEmail.Textbody = $as_Body & @CRLF
EndIf
If $s_AttachFiles <> "" Then
Local $S_Files2Attach = StringSplit($s_AttachFiles, ";")
For $x = 1 To $S_Files2Attach[0]
$S_Files2Attach[$x] = _PathFull($S_Files2Attach[$x])
;~ ConsoleWrite('@@ Debug : $S_Files2Attach[$x] = ' & $S_Files2Attach[$x] & @LF & '>Error code: ' & @error & @LF) ;### Debug Console
If FileExists($S_Files2Attach[$x]) Then
ConsoleWrite('+> File attachment added: ' & $S_Files2Attach[$x] & @LF)
$objEmail.AddAttachment($S_Files2Attach[$x])
Else
ConsoleWrite('!> File not found to attach: ' & $S_Files2Attach[$x] & @LF)
SetError(1)
Return 0
EndIf
Next
EndIf
$objEmail.Configuration.Fields.Item ("[url="http://schemas.microsoft.com/cdo/configuration/sendusing"]http://schemas.microsoft.com/cdo/configuration/sendusing"[/url]) = 2
$objEmail.Configuration.Fields.Item ("[url="http://schemas.microsoft.com/cdo/configuration/smtpserver"]http://schemas.microsoft.com/cdo/configuration/smtpserver"[/url]) = $s_SmtpServer
If Number($IPPort) = 0 then $IPPort = 25
$objEmail.Configuration.Fields.Item ("[url="http://schemas.microsoft.com/cdo/configuration/smtpserverport"]http://schemas.microsoft.com/cdo/configuration/smtpserverport"[/url]) = $IPPort
;Authenticated SMTP
If $s_Username <> "" Then
$objEmail.Configuration.Fields.Item ("[url="http://schemas.microsoft.com/cdo/configuration/smtpauthenticate"]http://schemas.microsoft.com/cdo/configuration/smtpauthenticate"[/url]) = 1
$objEmail.Configuration.Fields.Item ("[url="http://schemas.microsoft.com/cdo/configuration/sendusername"]http://schemas.microsoft.com/cdo/configuration/sendusername"[/url]) = $s_Username
$objEmail.Configuration.Fields.Item ("[url="http://schemas.microsoft.com/cdo/configuration/sendpassword"]http://schemas.microsoft.com/cdo/configuration/sendpassword"[/url]) = $s_Password
EndIf
If $ssl Then
$objEmail.Configuration.Fields.Item ("[url="http://schemas.microsoft.com/cdo/configuration/smtpusessl"]http://schemas.microsoft.com/cdo/configuration/smtpusessl"[/url]) = True
EndIf
;Update settings
$objEmail.Configuration.Fields.Update
; Set Email Importance
Switch $s_Importance
Case "High"
$objEmail.Fields.Item ("urn:schemas:mailheader:Importance") = "High"
Case "Normal"
$objEmail.Fields.Item ("urn:schemas:mailheader:Importance") = "Normal"
Case "Low"
$objEmail.Fields.Item ("urn:schemas:mailheader:Importance") = "Low"
EndSwitch
$objEmail.Fields.Update
; Sent the Message
$objEmail.Send
If @error Then
SetError(2)
Return $oMyRet[1]
EndIf
$objEmail=""
EndFunc ;==>_INetSmtpMailCom
;
;
; Com Error Handler
Func MyErrFunc()
$HexNumber = Hex($oMyError.number, 8)
$oMyRet[0] = $HexNumber
$oMyRet[1] = StringStripWS($oMyError.description, 3)
ConsoleWrite("### COM Error ! Number: " & $HexNumber & " ScriptLine: " & $oMyError.scriptline & " Description:" & $oMyRet[1] & @LF)
SetError(1); something to check for when this function returns
Return
EndFunc ;==>MyErrFunc