2015-06-29 75 views
2

我有两个单独的文档与邮件合并列表。我有两张工作表的Excel工作簿。根据工作表名称&如果工作表不是空的,我需要将mailmerge发送到相应的单词文档。运行时错误91:对象变量或未设置块变量

当我尝试执行此代码,它运行高达第一个文件,并在第二个文件,它与一个错误停止Run-time Error 91 : Object variable or With block variable not set

我不知道是什么导致这个错误(如果它是在昏暗的变量或用块)。如果有人能够帮助我纠正这个错误,我将不胜感激。

Sub Generate_Certificate() 

    Dim wd As Object 
    Dim wdoc_reg As Object 
    Dim wdoc_occ As Object 
    Dim strWbName_reg As String 
    Dim strWbName_occ As String 


    Const wdFormLetters = 0, wdOpenFormatAuto = 0 
    Const wdFormLetters1 = 0, wdOpenFormatAuto1 = 0 
    Const wdSendToNewDocument = 0, wdDefaultFirstRecord = 1, wdDefaultLastRecord = -16 
    Const wdSendToNewDocument1 = 0, wdDefaultFirstRecord1 = 1, wdDefaultLastRecord1 = -16 


    On Error Resume Next 
    Set wd = GetObject(, "Word.Application") 
    If wd Is Nothing Then 
     Set wd = CreateObject("Word.Application") 
    End If 
    On Error Goto 0 


    For Each Sheet In ActiveWorkbook.Sheets 

     'Generate report using "Mailmerge" if any data available for Mailmerge1 
     If Sheet.Name Like "Sheet1" And IsEmpty(ThisWorkbook.Sheets("Sheet1").Range("A2").Value) = False Then 
      Set wdoc_reg = wd.Documents.Open("C:\Mailmerge1.docx") 


      strWbName_reg = ThisWorkbook.Path & "\" & ThisWorkbook.Name 


      wdoc_reg.MailMerge.MainDocumentType = wdFormLetters 


      wdoc_reg.MailMerge.OpenDataSource _ 
      Name:=strWbName_reg, _ 
      AddToRecentFiles:=False, _ 
      Revert:=False, _ 
      Format:=wdOpenFormatAuto, _ 
      Connection:="Data Source=" & strWbName_reg & ";Mode=Read", _ 
      SQLStatement:="SELECT * FROM `Sheet1$`" 

      With wdoc_reg.MailMerge 
       .Destination = wdSendToNewDocument 
       .SuppressBlankLines = True 
       With .DataSource 
        .FirstRecord = wdDefaultFirstRecord 
        .LastRecord = wdDefaultLastRecord 
       End With 
       .Execute Pause:=False 
      End With 


      wd.Visible = True 
      wdoc_reg.Close SaveChanges:=False 


      Set wdoc_reg = Nothing 
      Set wd = Nothing 
     End If 


     'Generate report using "Mailmerge" if any data available for Mailmerge2 
     If Sheet.Name Like "Sheet2" And IsEmpty(ThisWorkbook.Sheets("Sheet2").Range("A2").Value) = False Then 
      Set wdoc_occ = wd.Documents.Open("C:\Mailmerge2.docx") 


      strWbName_occ = ThisWorkbook.Path & "\" & ThisWorkbook.Name 


      wdoc_occ.MailMerge.MainDocumentType = wdFormLetters1 


      wdoc_occ.MailMerge.OpenDataSource _ 
      Name:=strWbName_Occ, _ 
      AddToRecentFiles:=False, _ 
      Revert:=False, _ 
      Format:=wdOpenFormatAuto1, _ 
      Connection:="Data Source=" & strWbName_occ & ";Mode=Read", _ 
      SQLStatement:="SELECT * FROM `Sheet2$`" 


      With wdoc_occ.MailMerge 
       .Destination = wdSendToNewDocument1 
       .SuppressBlankLines = True 
       With .DataSource 
        .FirstRecord = wdDefaultFirstRecord1 
        .LastRecord = wdDefaultLastRecord1 
       End With 
       .Execute Pause:=False 
      End With 


      wd.Visible = True 
      wdoc_occ.Close SaveChanges:=False 


      Set wdoc_Occ = Nothing 
      Set wd = Nothing 
     End If 


    Next 


End Sub 
+3

您在循环中设置了“wd = Nothing”,这将在第一张纸后清除对Word的引用。把它移动到'End Sub'前面 –

+0

谢谢soooo,Tim!你是最好的!! 我删除了这一行,我的代码像魔术一样工作!再一次感谢你 :) –

回答

0

正如Tim Williams在问题的评论中所述。

您的环路中有Set wd = Nothing,它将在第一张纸后清除您对Word的引用。将其移动到End Sub

相关问题