Word VBA 急救!!! 100分!!

cyberkit 2006-01-01 12:24:23
为什么以下代码只能运行一次,第2次运行的时候就提示 "远程服务器不存在或不能使用"
必须将winword进程杀了之后才能再用,但用完一次之后,又不能用..........

Dim NewDoc As Document

Dim WordApp As New Word.Application
Set NewDoc = WordApp.Documents.Add

Dim Title As Range
Set Title = NewDoc.Range(Start:=0, End:=0)
With Title
.InsertAfter Text:="Hello"
.InsertParagraphAfter
With .Font
.Name = "黑体"
.Size = 18
.Bold = False
End With
End With
With NewDoc.Paragraphs(1)
.Alignment = wdAlignParagraphCenter
.SpaceAfter = InchesToPoints(0.2)
End With
Dim Rang2 As Range
Set Rang2 = NewDoc.Range(Start:=NewDoc.Paragraphs(2).Range.Start, End:=NewDoc.Paragraphs(2).Range.End)

With Rang2
.InsertAfter Text:="SOMETHING"
.InsertParagraphAfter
End With
NewDoc.Paragraphs(2).SpaceAfter = InchesToPoints(0.3)


Dim Rang3 As Range
Set Rang3 = NewDoc.Range(Start:=NewDoc.Paragraphs(3).Range.Start, End:=NewDoc.Paragraphs(3).Range.End)
Rang3.InsertAfter Text:=Format(Now, "YYYY年MM月DD日")
NewDoc.Paragraphs(3).Alignment = wdAlignParagraphRight

WordApp.Visible = True
Set WordApp = Nothing
...全文
200 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
laidon 2006-01-02
  • 打赏
  • 举报
回复
应该是引用的word版本的问题,另外,释放所有资源
faysky2 2006-01-01
  • 打赏
  • 举报
回复
我试了一下,点好多次也没问题,我引用的是 Word 10.0,以前好象也碰到过这个问题,是引用 11.0版本引起的
hhjjhjhj 2006-01-01
  • 打赏
  • 举报
回复
代码都要以定义好的对象变量开始,如:
InchesToPoints(xx)改成
WordApp.InchesToPoints(xx)
rainstormmaster 2006-01-01
  • 打赏
  • 举报
回复
//为什么以下代码只能运行一次,第2次运行的时候就提示 "远程服务器不存在或不能使用"
必须将winword进程杀了之后才能再用,但用完一次之后,又不能用..........

这个就是程序结束时,对象没清理干净,把你用到的全部对象都清理掉应该就可以了
northwolves 2006-01-01
  • 打赏
  • 举报
回复
我原以为你在VBA里用呢.前边加一句 On Error Resume Next 试试


Private Sub Command1_Click()
On Error Resume Next
Dim NewDoc As Document

Dim WordApp As New Word.Application
Set NewDoc = WordApp.Documents.Add

Dim Title As Range
Set Title = NewDoc.Range(Start:=0, End:=0)
With Title
.InsertAfter Text:="Hello"
.InsertParagraphAfter
With .Font
.Name = "黑体"
.Size = 18
.Bold = False
End With
End With
With NewDoc.Paragraphs(1)
.Alignment = wdAlignParagraphCenter
.SpaceAfter = InchesToPoints(0.2)
End With
Dim Rang2 As Range
Set Rang2 = NewDoc.Range(Start:=NewDoc.Paragraphs(2).Range.Start, End:=NewDoc.Paragraphs(2).Range.End)

With Rang2
.InsertAfter Text:="SOMETHING"
.InsertParagraphAfter
End With
NewDoc.Paragraphs(2).SpaceAfter = InchesToPoints(0.3)


Dim Rang3 As Range
Set Rang3 = NewDoc.Range(Start:=NewDoc.Paragraphs(3).Range.Start, End:=NewDoc.Paragraphs(3).Range.End)
Rang3.InsertAfter Text:=Format(Now, "YYYY年MM月DD日")
NewDoc.Paragraphs(3).Alignment = wdAlignParagraphRight

WordApp.Visible = True
Set WordApp = Nothing

End Sub


cyberkit 2006-01-01
  • 打赏
  • 举报
回复
你将这个代码放到一个command_click 里运行看看
多点几次command 看看有没有问题
cyberkit 2006-01-01
  • 打赏
  • 举报
回复
是在vb里运行啊,不是word
我的word是2003啊
northwolves 2006-01-01
  • 打赏
  • 举报
回复
我的机子上调试没问题,你的操作系统和WORD版本多少?
网管教程 从入门到精通软件篇 ★一。★详细的xp修复控制台命令和用法!!! 放入xp(2000)的光盘,安装时候选R,修复! Windows XP(包括 Windows 2000)的控制台命令是在系统出现一些意外情况下的一种非常有效的诊断和测试以及恢复系统功能的工具。小编的确一直都想把这方面的命令做个总结,这次辛苦老范给我们整理了这份实用的秘笈。   Bootcfg   bootcfg 命令启动配置和故障恢复(对于大多数计算机,即 boot.ini 文件)。   含有下列参数的 bootcfg 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 bootcfg 命令。   用法:   bootcfg /default  设置默认引导项。   bootcfg /add    向引导列表中添加 Windows 安装。   bootcfg /rebuild  重复全部 Windows 安装过程并允许用户选择要添加的内容。   注意:使用 bootcfg /rebuild 之前,应先通过 bootcfg /copy 命令备份 boot.ini 文件。   bootcfg /scan    扫描用于 Windows 安装的所有磁盘并显示结果。   注意:这些结果被静态存储,并用于本次会话。如果在本次会话期间磁盘配置发生变化,为获得更新的扫描,必须先重新启动计算机,然后再次扫描磁盘。   bootcfg /list   列出引导列表中已有的条目。   bootcfg /disableredirect 在启动引导程序中禁用重定向。   bootcfg /redirect [ PortBaudRrate] |[ useBiosSettings]   在启动引导程序中通过指定配置启用重定向。   范例: bootcfg /redirect com1 115200 bootcfg /redirect useBiosSettings   hkdsk   创建并显示磁盘的状态报告。Chkdsk 命令还可列出并纠正磁盘上的错误。   含有下列参数的 chkdsk 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 chkdsk 命令。   vol [drive:] [ chkdsk [drive:] [/p] [/r]   参数  无   如果不带任何参数,chkdsk 将显示当前驱动器中的磁盘状态。 drive: 指定要 chkdsk 检查的驱动器。 /p   即使驱动器不在 chkdsk 的检查范围内,也执行彻底检查。该参数不对驱动器做任何更改。 /r   找到坏扇区并恢复可读取的信息。隐含着 /p 参数。   注意 Chkdsk 命令需要 Autochk.exe 文件。如果不能在启动目录(默认为 %systemroot%System32)中找到该文件,将试着在 Windows 安装 CD 中找到它。如果有多引导系统的计算机,必须保证是在包含 Windows 的驱动器上使用该命令。 Diskpart   创建和删除硬盘驱动器上的区。diskpart 命令仅在使用故障恢复控制台时才可用。   diskpart [ /add |/delete] [device_name |drive_name |partition_name] [size]   参数 无   如果不带任何参数,diskpart 命令将启动 diskpart 的 Windows 字符模式版本。   /add   创建新的区。   /delete   删除现有区。   device_name   要创建或删除区的设备。设备名称可从 map 命令的输出获得。例如,设备名称:   DeviceHardDisk0   drive_name   以驱动器号表示的待删除区。仅与 /delete 同时使用。以下是驱动器名称的范例:   D:   partition_name   以区名称表示的待删除区。可代替 drive_name 使用。仅与 /delete 同时使用。以下是区名称的范例:   DeviceHardDisk0Partition1    大小   要创建的区大小,以兆字节 (MB)表示。仅与 /add 同时使用。   范例   下例将删除区: diskpart /delete Device HardDisk0 Partition3 diskpart /delete F:   下例将在硬盘上添加一个 20 MB 的区:   diskpart /add Device HardDisk0 20   Fixboot

7,762

社区成员

发帖
与我相关
我的任务
社区描述
VB 基础类
社区管理员
  • VB基础类社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧