Поделиться через


Пример еженедельного триггера (создание скриптов)

В этом примере скриптов показано, как создать задачу, которая запускает Блокнот в 8:00 по понедельнику каждой недели. Задача содержит ежедневный триггер, указывающий, когда выполняется задача, и исполняемое действие, которое запускает Блокнот.

В следующей процедуре описывается планирование задачи для запуска исполняемого файла в 8:00 по понедельнику каждой недели.

Планирование начала в Блокноте в 8:00 по понедельнику каждой недели

  1. Создайте объект TaskService . Этот объект позволяет создать задачу в указанной папке.

  2. Получите папку задач и создайте задачу. Используйте метод TaskService.GetFolder , чтобы получить папку, в которой хранится задача, и метод TaskService.NewTask для создания объекта TaskDefinition , представляющего задачу.

  3. Определите сведения о задаче с помощью объекта TaskDefinition . Используйте свойство TaskDefinition.Settings , чтобы определить параметры, определяющие, как служба планировщика задач выполняет задачу, и свойство TaskDefinition.RegistrationInfo для определения сведений, описывающих задачу.

  4. Создайте еженедельный триггер с помощью свойства TaskDefinition.Triggers . Это свойство предоставляет доступ к объекту TriggerCollection , который используется для создания триггера.

    Используйте метод TriggerCollection.Create (указывающий тип триггера, который вы хотите создать) для создания еженедельного триггера.

    Задайте свойство WeeklyTrigger.StartBoundary , чтобы указать время активации триггера и время суток, когда выполняется задача. В этом примере триггер активируется 1 января 2005 г., а задача выполняется в 8:00.

    Задайте свойство WeeklyTrigger.EndBoundary, чтобы указать, когда триггер деактивируется. В этом примере триггер деактивирован 1 января 2015 г.

    Задайте свойство WeeklyTrigger.DaysOfWeek , чтобы указать дни недели, в которые выполняется задача. В этом примере задача выполняется в понедельник.

    Задайте свойство WeeklyTrigger.WeeksInterval, чтобы указать интервал между неделями в расписании. В этом примере задача выполняется каждую неделю.

  5. Создайте действие для выполнения задачи с помощью свойства TaskDefinition.Actions . Это свойство предоставляет доступ к объекту ActionCollection , используемому для создания действия. Используйте метод ActionCollection.Create , чтобы указать тип создаваемого действия. В этом примере используется объект ExecAction , представляющий действие, которое выполняет операцию командной строки.

  6. Зарегистрируйте задачу с помощью метода TaskFolder.RegisterTaskDefinition . В этом примере задача будет запускаться в Блокноте в 8:00 по понедельнику каждой недели.

В следующем примере VBScript показано, как запланировать выполнение задачи в Блокноте каждый день в 8:00.

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

' A constant that specifies a weekly trigger.
const TriggerTypeWeekly = 3
' 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 weekly."
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 weekly trigger. Note that the start boundary 
' specifies the time of day that the task starts, the 
' day-of-week specfies on what day of the week the task 
' runs, and the interval specifies what weeks the task runs.
Dim triggers
Set triggers = taskDefinition.Triggers

Dim trigger
Set trigger = triggers.Create(TriggerTypeWeekly)

' Trigger variables that define when the trigger is active 
' and the time of day that the task is run. The format of 
' this tims 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.DaysOfWeek = 1
trigger.WeeksInterval = 1    'Task runs every week.
trigger.Id = "WeeklyTriggerId"
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 Weekly Trigger", taskDefinition, 6, , , 3)

WScript.Echo "Task submitted."

Использование планировщика задач