Günlük Tetikleyici Örneği (Betik Oluşturma)

Bu betik örneği, Not Defteri'nin her gün saat 08:00'de çalıştığı bir görevin nasıl oluşturulacağını gösterir. Görev, tetikleyiciyi etkinleştirmek ve görevin çalıştığı günün saatini belirtmek için bir başlangıç sınırı, görevin her gün çalıştırılacağını belirtmek için bir tetikleyici aralığı ve tetikleyiciyi devre dışı bırakmak için bir bitiş sınırı belirten günlük bir tetikleyici içerir. Örnekte, tetikleyicinin görevi yinelemek için yineleme deseninin nasıl ayarlanacağı da gösterilmektedir. Görev, Not Defteri'ni çalıştıran yürütülebilir bir eylem de içerir.

Aşağıdaki yordamda, her gün 08:00'da yürütülebilir dosya başlatmak için bir görevin nasıl zamanlandığı açıklanmaktadır. (Bu adımlar, örnek kodda yer alan kod açıklamalarına karşılık gelir.)

Not Defteri'ni her gün 08:00'de başlayacak şekilde zamanlamak için

  1. TaskService nesnesi oluşturun. Bu nesne, görevi belirtilen klasörde oluşturmanıza olanak tanır.
  2. Bir görev klasörü alın ve bir görev oluşturun. Görevin depolandığı klasörü almak için TaskService.GetFolder yöntemini ve görevi temsil eden TaskDefinition nesnesini oluşturmak için TaskService.NewTask yöntemini kullanın.
  3. TaskDefinition nesnesini kullanarak görevle ilgili bilgileri tanımlayın. Görev Zamanlayıcı hizmetinin görevi nasıl gerçekleştirdiğini belirleyen ayarları tanımlamak için TaskDefinition.Settings özelliğini ve görevi açıklayan bilgileri tanımlamak için TaskDefinition.RegistrationInfoözelliğinikullanın.
  4. TaskDefinition.Triggers özelliğini kullanarak günlük tetikleyici oluşturun. Bu özellik, tetikleyiciyi oluşturmak için kullanılan TriggerCollection nesnesine erişim sağlar. Günlük tetikleyici oluşturmak için TriggerCollection.Create yöntemini (oluşturmak istediğiniz tetikleyici türünü belirterek) kullanın. Tetikleyiciyi oluştururken, tetikleyiciyi etkinleştirmek için başlangıç sınırını ayarlayın ve görevin çalıştıracağı günün saatini, günler arasındaki aralığı ve tetikleyiciyi devre dışı bırakmak için bitiş sınırını belirtin. Aşağıdaki örnekte, tetikleyicinin görevi yinelemek için yineleme düzeninin nasıl ayarlanacağı gösterilmektedir.
  5. TaskDefinition.Actions özelliğini kullanarak görevin yürütülmesi için bir eylem oluşturun. Bu özellik, eylemi oluşturmak için kullanılan ActionCollection nesnesine erişim sağlar. Oluşturmak istediğiniz eylem türünü belirtmek için ActionCollection.Create yöntemini kullanın. Bu örnekte, komut satırı işlemini yürüten bir eylemi temsil eden ExecAction nesnesi kullanılır.
  6. TaskFolder.RegisterTaskDefinition yöntemini kullanarak görevi kaydedin. Bu örnekte görev, Not Defteri'ni her gün 08:00'da başlatır.

Aşağıdaki VBScript örneğinde, Not Defteri'ni her gün saat 08:00'de yürütmek üzere bir görevin nasıl zamanlandığı gösterilmektedir.

'------------------------------------------------------------------
' 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."

Görev Zamanlayıcı Kullanarak