这是MS-Word宏。 它产生了这个错误:
错误4605"此方法或属性不可用,因为有 内存或磁盘问题
' Word script to remove all unused styles in the document
Sub DeleteUnusedStyles()
Dim Doc As Document, bDel As Boolean
Dim Rng As Range, StlNm As String, i As Long
Application.ScreenUpdating = False
Set Doc = ActiveDocument
With Doc
For i = .Styles.Count To 1 Step -1
With .Styles(i)
If .BuiltIn = False Then
bDel = True: StlNm = .NameLocal
For Each Rng In Doc.StoryRanges
With Rng
With .Find
.ClearFormatting
.Format = True
.Style = StlNm
.Execute
End With
If .Find.Found = True Then
bDel = False
Exit For
End If
End With
Next
If bDel = True Then .Delete
End If
End With
Next
End With
Application.ScreenUpdating = True
End Sub
它应该从word文档中删除所有未使用的样式。我在互联网上找到并测试了其他3个应该做同样事情的宏,但最后会出现同样的错误。 Word文档暂停约5分钟(它的100页文档格式很大)然后它会吐出这个错误。在错误出现之前,我可以看到单词进程的内存消耗增加了近5倍。我仍然有足够的RAM。我在Windows 8.1 x86_64上运行正版Word 2013。为什么会发生这种情况?如何修复错误?
答案 0 :(得分:2)
在这种情况下,显然Undo堆栈会堵塞。
简单修复:修改如下代码:
'...
'...
Next
If bDel = True Then .Delete
Doc.UndoClear
End If
End With
答案 1 :(得分:0)
从文件/选项/自定义的ribon中启用“开发人员”菜单。
然后按ALT-F11并将此代码粘贴到那里。 按F5。
Sub Removedenter code hereNonDefaultStyles()
Dim CurrentStyleInLoop As Style
For Each CurrentStyleInLoop In ActiveDocument.Styles
If Not CurrentStyleInLoop.BuiltIn Then
CurrentStyleInLoop.Delete
End If
Next CurrentStyleInLoop
End Sub