【发布时间】:2021-01-27 20:08:56
【问题描述】:
我通过 Excel vba 创建了两个新的 Word 文档,尚未保存。文档被创建为“Document1”和“Document2”。当我尝试在文档之间切换时,我收到 Document2 的错误文件名错误 4160。请帮我解决这个问题。
Sub DocSwitch()
Dim s As Object
Set s = Word.Application.Selection
Documents("Document1").Select
s.TypeText Text:="Hello"
Documents("Document2").Select
s.TypeText Text:="Hi"
End Sub
【问题讨论】:
-
Set s = Word.Application.Selection- 执行此操作后,s指向该行运行时选择的任何内容,并且在您选择其他内容时不会动态更新。如果您激活其他文档,则需要重复该行。 -
嗨蒂姆威廉姆斯,程序没有进入第二个 s.TypeText,它在 Documents("Document2") 上给出了错误的文件名错误。
-
您在哪一行得到错误?您的文档是否可能位于不同的 Word 实例中?
-
此外,您为什么要将焦点从一个文档切换到另一个文档并使用 Select?您可以直接处理任一文档而无需这样做。例如:stackoverflow.com/questions/56251088/…、stackoverflow.com/questions/61051991/… & stackoverflow.com/questions/64853079/…
-
Tim Williams:我收到错误行“Documents("Document2").Select”。它们是从同一个 Excel 文件的两个不同宏创建的。正如查尔斯所说,将文档变量分配给每个新文档解决了这个问题。 macropod:我是 vba 和学习的新手..,感谢您提供宝贵的链接。