我设计了一个简单的解决方案,让五个人的团队自动了解团队的日常关键任务是否完成。我为每个任务创建一个单独的任务,并将任务的提醒设置为与任务的时间相同(前0分钟)。结构是这样的;任务所有者完成任务,拍摄屏幕截图(作为证明。这是必须的),并将其与预定义的文件名一起保存在特定的文件夹(file.jpg)中。弹出相关的Outlook任务提醒,运行代码以查找此文件,如果找到该文件,则不执行任何操作;如果该文件不存在,请向团队发送一封电子邮件,说明任务尚未完成。代码保存在Outlook的application_reminder下,而我在模块下也保存了一些功能。在前一两个实例的任务提醒触发后,代码运行良好,但是由于某种原因而停止工作。提示弹出,但代码不运行。
我在下面粘贴了代码,仅供参考。正如我所说的,代码仅在最初的情况下起作用。但是总是欢迎提出改进建议。
Private Sub Application_Reminder(ByVal Item As Object)
Dim objPeriodicalMail As MailItem
If Item.Categories = "Screenshot" Then
Call Screenshot(Item.Subject)
End If
End Sub
*************************
Function reppdate() As Date 'returns previous working date
Dim yest As Date
Dim tatiller As Variant
tatiller = Array("19.05.2020", "06.05.2020", "05.05.2020", "04.05.2020", "01.05.2020", "01.01.2020") 'local holidays
j = -1
For i = 0 To UBound(tatiller)
yest = Format(DateAdd("w", j, Now()), "dd.mm.yyyy")
If yest = tatiller(i) Then
If Weekday(yest) = 2 Then
j = j - 3
Else: j = j - 1
End If
Else
If j < -1 Then
Exit For
Else: End If
End If
Next i
reppdate = yest
End Function
**************************************
Sub Screenshot(dosya As String)
yestt = reppdate()
Dim objMsg As MailItem
Set objMsg = Application.CreateItem(olMailItem)
vamsg = "Dikkat, " & dosya & ".jpg bulunamadi, rapor gönderilmemis mi!"
dosyaadi1 = "c:folder\" & Format(yestt, "yyyymm") & "\Daily\" & Format(yestt, "dd") & "\" & dosya & ".jpg"
baglanti = "<a href=" & dosyaadi1 & ">" & vamsg & "</a>"
If FileFolderExists(dosyaadi1) = False Then
msg = vamsg
Else
End If
objMsg.To = "vvvvv.com"
objMsg.Subject = msg
objMsg.Body = msg & " - " & dosyaadi1
objMsg.Send
Set objMsg = Nothing
End Sub
Categories
属性值可以包括分配的另一个字符串类别。因此,我建议改为检查具有特定值的子字符串。 Contains = InStr(strBaseString, strSearchTerm)
Categories
是已分配给Outlook项目的类别名称的定界字符串。此属性使用Windows注册表中HKEY_CURRENT_USER \ Control Panel \ International下的值名称sList中指定的字符作为多个类别的分隔符。要将类别名称的字符串转换为类别名称的数组,请使用Microsoft Visual Basic函数Split
。
我建议在调试器下运行代码,并查看其工作方式和失败之处。另外,您可以添加错误处理例程,请参见Error Handling in VBA。
没有直接迁移。基本上,您必须创建一个新的外接程序项目并在其中添加事件处理程序。然后,您可以将代码从VBA事件处理程序设置为外接程序的代码。有关更多信息,请参见https://docs.microsoft.com/en-us/previous-versions/office/developer/office-2007/aa830702(v=office.12)?redirectedfrom=MSDN和Create VSTO Add-ins for Office by using Visual Studio。