0

我发现此参考将更新 Word 文档中的所有字段。http://www.gmayor.com/installing_macro.htm

Sub UpdateAll()
    Dim oStory As Range
    For Each oStory In ActiveDocument.StoryRanges
        oStory.Fields.Update
        If oStory.StoryType <> wdMainTextStory Then
            While Not (oStory.NextStoryRange Is Nothing)
                Set oStory = oStory.NextStoryRange
                oStory.Fields.Update
            Wend
        End If
    Next oStory
    Set oStory = Nothing
End Sub

我想将其修改为仅DocProperty使用此宏更新类型的字段。

例如:我想更新所有DocProperty类型,同时跳过所有Ref类型或所有其他类型。

4

1 回答 1

0

您可以Type在更新之前检查 fields 属性,但您必须遍历它们。

有很多方法可以做到这一点,但我把循环放在一个 sub 中,所以你可以改变你的两个更新行

oStory.Fields.Update

Call UpdateRangeFieldsOfType(oStory, wdFieldDocProperty)


这是子:

Sub UpdateRangeFieldsOfType(poRange As Range, peType As WdFieldType)
    Dim oField As Field

    For Each oField In poRange.Fields
        If oField.Type = peType Then
            oField.Update
        End If
    Next
    Set oField = Nothing
End Sub
于 2012-08-16T10:22:30.630 回答