Outlook 2010, автоответчик, если меня нет на месте
Можно ли создать стандартный автоответ в outlook, если календарь показывает, что я "вне офиса"?
Это может быть только несколько часов, что я "вне офиса", поэтому в сообщении должен быть указан период автоматически?
Спасибо за ответ.
1 ответ
Outlook не делает это напрямую, но вы можете сделать это с помощью макроса.
Автоматизация OOF (вне офиса) - это автоматизация на основе VBScript, которая включает автоматическое включение OOF Assistant, когда соответствующий пользователь ввел "выездную" встречу, и обратно, когда больше нет "выездной" встречи.
Это работает с использованием CDO извне с помощью планировщика заданий, например, все 30 минут. Существует также внутреннее решение, которое можно найти на CDOLive. Однако при его реализации у меня возникла проблема с MAPI, поскольку мое сообщение Outlook OOF внезапно не синхронизировалось с сообщением, измененным в сценарии.
'TO CONFIGURE: Change "ServerName" to the name of your Exchange Server
Const sServerName = "OEBFASRV02"
'TO CONFIGURE: Change "MailboxName" to the name
'of an administrative mailbox on the server specified above
Dim sProfileInfo ' the MAPI logon profile
sProfileInfo = sServerName & vbLf & "Administrator"
'TO CONFIGURE: Change placeholders and
'infixes to reflect your used languages
'(2 at most, if more are needed then change the code yourself...)
Const placeHolderLang1 = "<Datum>"
Const placeHolderLang2 = "<Date>"
Const infixFrom1 = "von "
Const infixFrom2 = "from "
Const infixTo1 = " bis "
Const infixTo2 = " to "
Const infixOn1 = "am "
Const infixOn2 = "on "
'TO CONFIGURE: Send Mails to these people in case of error.
Const ErrMailDistributionList = "rkapl"
Log.vbs
Log.vbs is a separately usable, simple Logger class. It can be used in other scripts as follows:
Set WshShell = WScript.CreateObject("WScript.Shell")
ExecuteGlobal CreateObject(_
"Scripting.FileSystemObject").OpenTextFile("Log.vbs", 1).ReadAll
' PathToLogFolder.. (default = defaultLogPath in Log.vbs)
' NameOfLogFile.. (default = scriptname)
' maxLevelToBeLogged.. 0 = ERROR, _
' 1 = WARN, 2 = INFO, 3 = DEBUG (default)
' CommaSeparatedErrMailDistributionListString...
' e.g. "admin1, admin2, admin3" (default = defaultMailRecipients in Log.vbs)
' ErrMailSender.. (default = defaultMailSender in Log.vbs)
' ErrMailSubject.. (default = defaultMailSubject in Log.vbs)
Set theLogger = new_Logger(Array(PathToLogFolder,NameOfLogFile,_
maxLevelToBeLogged,CommaSeparatedErrMailDistributionListString, _
ErrMailSender,ErrMailSubject))
theLogger.LogInfo "Info Message"
theLogger.LogWarn "Warning Message"
theLogger.LogError "Error Message"
theLogger.LogStream (WshShell.Exec object)
'logs stderr output of Exec object as
'LogError messages, all other are logged as LogInfo
theLogger.LogFatal "Fatal Message (stops the script)"
Однако, это также должно быть настроено перед использованием:
'TO CONFIGURE: Send Mails to these default
'people in case of error (if not set by using script).
Const defaultMailRecipients = "rkapl,mkovacs,gnebenfuehr,mhoessl,gschrenk"
'TO CONFIGURE: The default sender of the error mails
Const defaultMailSender = "Administrator@oebfa.co.at"
'TO CONFIGURE: The default subject of error mails
Const defaultMailSubject = "Process Error"
'TO CONFIGURE: The file, where internal errors are logged
Const internalLogFile = _
"\\oebfasrv01\marktdaten\Logs\Log.vbs.internalErrs.log"
'TO CONFIGURE: The folder, where log files are being put
Const defaultLogPath = "\\oebfasrv01\marktdaten\Logs"