4

我正在尝试从 Excel 访问 MS Word 的窗口。我找到了访问新 Word 文档或特定文档的方法,例如 Copy Text from Range in Excel into Word Document中的方法,

但就我而言,我不知道文件的名称,它应该是最后一个活动的。我希望使用类似的东西

Word.ActiveDocument

但没有成功。我还尝试模拟 Alt+Tab 击键来激活窗口

Application.SendKeys("%{TAB}")

但它也不起作用。有什么提示吗?

我正在尝试创建一个宏,它只会将图表和一些文本复制到 Word 中,并对文本进行一些格式化。所以基本上我可以使用任何方法来完成这项任务。非常感谢。

4

1 回答 1

5

您可以使用后期绑定 ( http://support.microsoft.com/kb/245115 ) 和GetObject. 如果您打开了多个 Word 实例,则不能保证您会获得其中的任何一个。

获取 Word 实例将允许您访问ActiveDocument应用程序的当前Selection. 我仍然建议做一些错误检查,以确保你得到了你想要的。

    Sub GetWordDocument()
        Dim wdApp As Object

        'Turn off error handling since if the Application is not found we'll get an error
        'Use Late Binding and the GetObject method to find any open instances of Word
        On Error Resume Next
        Set wdApp = GetObject(, "Word.Application")
        On Error GoTo 0

        'Check to see if we found an instance.  If not you can create one if you desire
        If wdApp Is Nothing Then
            MsgBox "No instances of Word found"
            Exit Sub
        End If

        'Check if there are documents in the found instance of Word
        If wdApp.Documents.Count > 0 Then
            wdApp.Selection.TypeText "Cool, we got it" & vbCr

            'You can now access any of the active document properties too
            wdApp.ActiveDocument.Range.InsertAfter "We did indeed"
        End If

        'Clean up the Object when Finished
        Set wdApp = Nothing
    End Sub
于 2013-02-21T20:29:12.690 回答