時間觸發程式範例 (腳本)
此腳本範例示範如何建立在特定時間執行記事本的工作。 工作包含以時間為基礎的觸發程式,指定要啟動工作的開始界限、執行記事本的可執行動作,以及停用工作的結束界限。
下列程式描述如何排程工作在特定時間啟動可執行檔。
若要排程記事本在特定時間開始
- 建立 TaskService 物件。 這個物件可讓您在指定的資料夾中建立工作。
- 取得工作資料夾並建立工作。 使用 TaskService.GetFolder 方法來取得工作儲存所在的資料夾,以及 TaskService.NewTask 方法可建立代表工作的 TaskDefinition 物件。
- 使用 TaskDefinition 物件定義工作的相關資訊。 使用 TaskDefinition.Settings 屬性來定義設定,以決定工作排程器服務如何執行工作和 TaskDefinition.RegistrationInfo 屬性來定義描述工作的資訊。
- 使用 TaskDefinition.Triggers 屬性建立以時間為基礎的觸發程式。 此屬性提供 TriggerCollection 物件的存取權。 使用 TriggerCollection.Create 方法 (指定您想要建立的觸發程式類型,) 建立以時間為基礎的觸發程式。 當您建立觸發程式時,請設定觸發程式的開始界限和結束界限,以啟用和停用觸發程式。 開始界限會指定何時執行工作的動作。
- 使用 TaskDefinition.Actions 屬性建立要執行之工作的動作。 此屬性提供 ActionCollection 物件的存取權。 使用 ActionCollection.Create 方法可指定您想要建立的動作類型。 這個範例使用 ExecAction 物件,代表執行命令列作業的動作。
- 使用 TaskFolder.RegisterTaskDefinition 方法註冊 工作。 在此範例中,工作會在目前時間啟動 [記事本] 加上 30 秒。
下列 VBScript 範例示範如何排程工作,以在註冊工作之後 30 秒執行記事本。
'------------------------------------------------------------------
' This sample schedules a task to start notepad.exe 30 seconds
' from the time the task is registered.
'------------------------------------------------------------------
' A constant that specifies a time-based trigger.
const TriggerTypeTime = 1
' A constant that specifies an executable action.
const ActionTypeExec = 0
'********************************************************
' Create the TaskService object.
Set service = CreateObject("Schedule.Service")
call service.Connect()
'********************************************************
' Get a folder to create a task definition in.
Dim rootFolder
Set rootFolder = service.GetFolder("\")
' The taskDefinition variable is the TaskDefinition object.
Dim taskDefinition
' The flags parameter is 0 because it is not supported.
Set taskDefinition = service.NewTask(0)
'********************************************************
' Define information about the task.
' Set the registration info for the task by
' creating the RegistrationInfo object.
Dim regInfo
Set regInfo = taskDefinition.RegistrationInfo
regInfo.Description = "Start notepad at a certain time"
regInfo.Author = "Author Name"
'********************************************************
' Set the principal for the task
Dim principal
Set principal = taskDefinition.Principal
' Set the logon type to interactive logon
principal.LogonType = 3
' Set the task setting info for the Task Scheduler by
' creating a TaskSettings object.
Dim settings
Set settings = taskDefinition.Settings
settings.Enabled = True
settings.StartWhenAvailable = True
settings.Hidden = False
'********************************************************
' Create a time-based trigger.
Dim triggers
Set triggers = taskDefinition.Triggers
Dim trigger
Set trigger = triggers.Create(TriggerTypeTime)
' Trigger variables that define when the trigger is active.
Dim startTime, endTime
Dim time
time = DateAdd("s", 30, Now) 'start time = 30 seconds from now
startTime = XmlTime(time)
time = DateAdd("n", 5, Now) 'end time = 5 minutes from now
endTime = XmlTime(time)
WScript.Echo "startTime :" & startTime
WScript.Echo "endTime :" & endTime
trigger.StartBoundary = startTime
trigger.EndBoundary = endTime
trigger.ExecutionTimeLimit = "PT5M" 'Five minutes
trigger.Id = "TimeTriggerId"
trigger.Enabled = True
'***********************************************************
' Create the action for the task to execute.
' Add an action to the task to run notepad.exe.
Dim Action
Set Action = taskDefinition.Actions.Create( ActionTypeExec )
Action.Path = "C:\Windows\System32\notepad.exe"
WScript.Echo "Task definition created. About to submit the task..."
'***********************************************************
' Register (create) the task.
call rootFolder.RegisterTaskDefinition( _
"Test TimeTrigger", taskDefinition, 6, , , 3)
WScript.Echo "Task submitted."
'------------------------------------------------------------------
' Used to get the time for the trigger
' startBoundary and endBoundary.
' Return the time in the correct format:
' YYYY-MM-DDTHH:MM:SS.
'------------------------------------------------------------------
Function XmlTime(t)
Dim cSecond, cMinute, CHour, cDay, cMonth, cYear
Dim tTime, tDate
cSecond = "0" & Second(t)
cMinute = "0" & Minute(t)
cHour = "0" & Hour(t)
cDay = "0" & Day(t)
cMonth = "0" & Month(t)
cYear = Year(t)
tTime = Right(cHour, 2) & ":" & Right(cMinute, 2) & _
":" & Right(cSecond, 2)
tDate = cYear & "-" & Right(cMonth, 2) & "-" & Right(cDay, 2)
XmlTime = tDate & "T" & tTime
End Function
相關主題