跳至主要内容

如何在Outlook中创建新任务时将默认开始日期设置为今天?

Author: Xiaoyang Last Modified: 2025-05-07

当我们在Outlook中创建一个新任务时,默认情况下“开始日期”会显示为“”,如下图所示。但是,有时您需要频繁地将今天的日期设置为开始日期,因此每次都需要手动在“开始日期”字段中选择日期。有没有一种快速的方法可以在Outlook中创建新任务时自动将默认开始日期设置为今天呢?

the screenshot of step about using vba to set the default start date as today when creating new task in Outlook 1

使用VBA代码在Outlook中创建新任务时将默认开始日期设置为今天


使用VBA代码在Outlook中创建新任务时将默认开始日期设置为今天

也许没有其他更好的方法可以直接在Outlook中处理此任务,这里我将介绍一个VBA代码来解决它。请按照以下步骤操作:

1. 启动Outlook,然后按住ALT + F11键打开Microsoft Visual Basic for Applications窗口。

2. 在Microsoft Visual Basic for Applications窗口中,双击Project1(VbaProject.OTM)窗格中的ThisOutlookSession以打开模块,然后将以下代码复制并粘贴到空白模块中。

VBA代码:将默认开始日期设置为今天:

Public WithEvents xInspectors As Outlook.Inspectors
Public WithEvents xTaskItem As Outlook.TaskItem
Private Sub Application_Startup()
   Set xInspectors = Outlook.Inspectors
End Sub
Private Sub xInspectors_NewInspector(ByVal Inspector As Inspector)
    If Not (TypeOf Inspector.CurrentItem Is TaskItem) Then Exit Sub
    Set xTaskItem = Inspector.CurrentItem
End Sub
Private Sub xTaskItem_Open(Cancel As Boolean)
If (Len(xTaskItem.Subject) = 0 And Len(xTaskItem.Body) = 0) And (xTaskItem.StartDate = #1/1/4501# And xTaskItem.DueDate = #1/1/4501#) Then
    xTaskItem.StartDate = Now
End If
End Sub
the screenshot of step about using vba to set the default start date as today when creating new task in Outlook 2

3. 插入代码后,将光标放在第二段代码处,然后按 F5键运行此代码,如下图所示:

the screenshot of step about using vba to set the default start date as today when creating new task in Outlook 3

4. 从那时起,每当您创建新任务时,Outlook将默认自动将开始日期和结束日期设置为当前日期,如下图所示:

the screenshot of step about using vba to set the default start date as today when creating new task in Outlook 4