ExcelTip.Net留存知识帖 ---【注:附件之前被网盘供应商清空后,现已修复-现已修复-现已修复为本地下载!】
现在位置:首页 > E问E答 > Excel VBA > 如何在Excel VBA中新建Word文档并使该文档窗口成为当前活动窗口呢?

如何在Excel VBA中新建Word文档并使该文档窗口成为当前活动窗口呢?

作者:绿色风 分类: 时间:2022-08-17 浏览:126
楼主
0Mouse
Q:如何在Excel VBA中新建Word文档并使该文档窗口成为当前活动窗口呢?
A:思路:先用GetObject捕获可能已经存在的Word进程,如果不存在Word进程,则采用CreateObject函数创建新的Word进程。捕获或创建Word进程后,新建一个Word文档,然后借助API函数捕获该文档窗口的句柄,再将该句柄窗口置于所有窗口的前面。代码如下:
  1. Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
  2. Declare Function BringWindowToTop Lib "user32" (ByVal hwnd As Long) As Long
  3.    
  4. Sub 在ExcelVBA中新建Word文档并使该文档窗口成为当前活动窗口()
  5.     Dim wordapp As Object, worddoc As Object, hwnd&
  6.     On Error Resume Next
  7.     Set wordapp = GetObject(, "Word.Application")
  8.     If wordapp Is Nothing Then Set wordapp = CreateObject("Word.Application")
  9.     Set worddoc = wordapp.Documents.Add
  10.     wordapp.Visible = True
  11.     hwnd = FindWindow(vbNullString, worddoc.Name & " - " & wordapp.Caption)
  12.     BringWindowToTop hwnd
  13. End Sub
附件:
在ExcelVBA中新建Word文档并使该文档窗口成为当前活动窗口.rar
2楼
云龙
顶起,辛苦了
3楼
ctzl
版主,这个很好,经常用到的哟,灰常的感谢分享!

如果,如果弹出一个保存路径,默认路径是桌面, 默认名称是   “我的文档” 名称,

怎么增加呢,请版主,完美下好吧,大家都会用到的哟!
4楼
ctzl
版主,这个很好,经常用到的哟,灰常的感谢分享!

如果,如果弹出一个保存路径,默认路径是桌面, 默认名称是   “我的文档” 名称,

怎么增加呢,请版主,完美下好吧,大家都会用到的哟!
5楼
老糊涂
下载学习

免责声明

有感于原ExcelTip.Net留存知识的价值及部分知识具有的时间限定性因素, 经与ExcelTip.Net站长Apolloh商议并征得其同意, 现将原属ExcelTip.Net的知识帖采集资料于本站点进行展示, 供有需要的人士查询使用,也慰缅曾经的论坛时代。 所示各个帖子的原作者如对版权有异议, 可与本人沟通提出,或于本站点留言,我们会尽快处理。 在此,感谢ExcelTip.Net站长Apolloh的支持,感谢本站点所有人**绿色风(QQ:79664738)**的支持与奉献,特此鸣谢!
------本人网名**KevinChengCW(QQ:1210618015)**原ExcelTip.Net总版主之一

评论列表
sitemap