我收到此Object Required错误.见下面的代码.我不明白为什么我得到它.oitem变量被声明为Object,我在尝试移动之前对"MailItem"类型进行了测试.请指教.
艾伦
Public StatsArchiveFolder As Outlook.Folder
'StatsArchiveFolder is set to equal an Outlook.Folder elsewhere
_____________________________________
Sub MoveHarpStatMail()
Dim olapp As Outlook.Application
Dim olappns As Outlook.NameSpace
Dim oitem As Object
Dim ItemsToProcess As Outlook.Items
Dim myFolder As MAPIFolder
Dim sFilter As String
Dim tempMailItem As Outlook.MailItem
On Error GoTo LocalErr
'set outlook objects
Set olapp = New Outlook.Application
Set olappns = olapp.GetNamespace("MAPI")
Set myFolder = olappns.GetDefaultFolder(olFolderInbox)
'Filter or only MailItems received today
sFilter = "[ReceivedTime] >= " & AddQuotes(Format(Date, "ddddd"))
Set ItemsToProcess = Session.GetDefaultFolder(olFolderInbox).Items.Restrict(sFilter)
For Each oitem In ItemsToProcess
If TypeName(oitem) = "MailItem" Then
Set tempMailItem = oitem
If CheckSubject(tempMailItem.Subject) Then
MoveToArchiveFolder (tempMailItem) '<<<Error 424 Object Required ???
End If
End If
Next oitem
ExitProc:
Set olapp = Nothing
Set olappns = Nothing
Set myFolder = Nothing
Set ItemsToProcess = Nothing
...
End Sub
_________________________________
Function CheckSubject(Subject As String) As Boolean
If (LCase(Trim(Subject)) = LCase(SubjectTitle)) Then
CheckSubject = True
Else
CheckSubject = False
End If
End Function
______________________________
Sub MoveToArchiveFolder(Item As Outlook.MailItem)
If (ArchiveFolder = Nothing) Then
MsgBox ("The ArchiveFolder object is not set.")
End If
Item.Move (StatsArchiveFolder)
End Sub
Run Code Online (Sandbox Code Playgroud)
删除括号:
MoveToArchiveFolder tempMailItem
Run Code Online (Sandbox Code Playgroud)
基本上括号说评估价值tempMailItem.a的默认属性MailItem是电子邮件的主题,因此您的代码将传递tempMailItem给您的函数而不是MailItem它自己.
这是一篇有趣的Daily Dose帖子,讲述为什么.一定要阅读Rick Rothstein的评论.
| 归档时间: |
|
| 查看次数: |
3417 次 |
| 最近记录: |