Freigeben über


Tägliches Triggerbeispiel (Skripting)

In diesem Skriptbeispiel wird gezeigt, wie Sie jeden Tag um 8:00 Uhr eine Aufgabe erstellen, die Editor ausführt. Die Aufgabe enthält einen täglichen Trigger, der eine Startgrenze angibt, um den Trigger zu aktivieren und die Tageszeit anzugeben, zu der der Task ausgeführt wird, ein Triggerintervall, um anzugeben, dass der Task täglich ausgeführt wird, und eine Endgrenze, um den Trigger zu deaktivieren. Das Beispiel zeigt auch, wie ein Wiederholungsmuster für den Trigger festgelegt wird, um die Aufgabe zu wiederholen. Der Task enthält auch eine ausführbare Aktion, die Editor ausführt.

Das folgende Verfahren beschreibt, wie Sie einen Task so planen, dass eine ausführbare Datei täglich um 8:00 Uhr gestartet wird. (Diese Schritte entsprechen den Codekommentaren, die im Beispielcode enthalten sind.)

So planen Sie, dass Editor jeden Tag um 8:00 Uhr beginnt

  1. Erstellen Sie ein TaskService-Objekt . Mit diesem Objekt können Sie die Aufgabe in einem angegebenen Ordner erstellen.
  2. Rufen Sie einen Aufgabenordner ab, und erstellen Sie eine Aufgabe. Verwenden Sie die TaskService.GetFolder-Methode , um den Ordner abzurufen, in dem die Aufgabe gespeichert ist, und die TaskService.NewTask-Methode , um das TaskDefinition-Objekt zu erstellen, das den Task darstellt.
  3. Definieren Sie Informationen zum Task mithilfe des TaskDefinition-Objekts . Verwenden Sie die TaskDefinition.Settings-Eigenschaft , um die Einstellungen zu definieren, die bestimmen, wie der Taskplaner-Dienst die Aufgabe ausführt, und die TaskDefinition.RegistrationInfo-Eigenschaft , um die Informationen zu definieren, die den Vorgang beschreiben.
  4. Erstellen Sie mithilfe der TaskDefinition.Triggers-Eigenschaft einen täglichen Trigger. Diese Eigenschaft bietet Zugriff auf das TriggerCollection-Objekt , das zum Erstellen des Triggers verwendet wird. Verwenden Sie die TriggerCollection.Create-Methode (geben Sie den Typ des Triggers an, den Sie erstellen möchten), um einen täglichen Trigger zu erstellen. Legen Sie beim Erstellen des Triggers die Startgrenze fest, um den Trigger zu aktivieren, und geben Sie die Tageszeit, zu der der Task ausgeführt wird, das Intervall zwischen den Tagen und die Endgrenze an, um den Trigger zu deaktivieren. Das folgende Beispiel zeigt, wie Sie ein Wiederholungsmuster für den Trigger festlegen, um die Aufgabe zu wiederholen.
  5. Erstellen Sie mithilfe der TaskDefinition.Actions-Eigenschaft eine Aktion für die auszuführende Aufgabe. Diese Eigenschaft bietet Zugriff auf das ActionCollection-Objekt , das zum Erstellen der Aktion verwendet wird. Verwenden Sie die ActionCollection.Create-Methode , um den Typ der Aktion anzugeben, die Sie erstellen möchten. In diesem Beispiel wird ein ExecAction-Objekt verwendet, das eine Aktion darstellt, die einen Befehlszeilenvorgang ausführt.
  6. Registrieren Sie den Task mithilfe der TaskFolder.RegisterTaskDefinition-Methode . In diesem Beispiel wird der Editor jeden Tag um 8:00 Uhr gestartet.

Das folgende VBScript-Beispiel zeigt, wie Sie eine Aufgabe so planen, dass Editor täglich um 8:00 Uhr ausgeführt wird.

'------------------------------------------------------------------
' This sample schedules a task to start on a daily basis.
'------------------------------------------------------------------

' A constant that specifies a daily trigger.
const TriggerTypeDaily = 2
' 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 8:00AM daily"
regInfo.Author = "Administrator"

' 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 daily trigger. Note that the start boundary 
' specifies the time of day that the task starts and the 
' interval specifies what days the task is run.
Dim triggers
Set triggers = taskDefinition.Triggers

Dim trigger
Set trigger = triggers.Create(TriggerTypeDaily)

' Trigger variables that define when the trigger is active 
' and the time of day that the task is run. The format of 
' this time is YYYY-MM-DDTHH:MM:SS
Dim startTime, endTime

Dim time
startTime = "2006-05-02T08:00:00"  'Task runs at 8:00 AM
endTime = "2015-05-02T08:00:00"

WScript.Echo "startTime :" & startTime
WScript.Echo "endTime :" & endTime

trigger.StartBoundary = startTime
trigger.EndBoundary = endTime
trigger.DaysInterval = 1    'Task runs every day.
trigger.Id = "DailyTriggerId"
trigger.Enabled = True

' Set the task repetition pattern for the task.
' This will repeat the task 5 times.
Dim repetitionPattern
Set repetitionPattern = trigger.Repetition
repetitionPattern.Duration = "PT4M"
repetitionPattern.Interval = "PT1M"

'***********************************************************
' 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 Daily Trigger", taskDefinition, 6, , , 3)

WScript.Echo "Task submitted."

Verwenden des Aufgabenplanungsmoduls