限制/锁定书签以进行单词编辑

时间:2014-01-16 14:01:00

标签: vba ms-word word-vba bookmarks restriction

我有很多带有大量书签的word文档。 我使用VBA代码用数据库中的数据更改这些书签。

问题是,有时用户需要编辑这些文档,他们往往会意外删除/更改我的书签,这导致VBA代码不再识别书签。

基本上,我想知道的是我如何限制用户在word文档中编辑我的书签。

我不需要超级安全的解决方案,只需要足够的保护,以便用户知道“我不应该触摸这部分”。

提前感谢您的回答..

编辑:

我正在不同的论坛上阅读,并且遇到了这个,

http://social.msdn.microsoft.com/Forums/office/en-US/f70ca604-bbdb-4b5a-8363-f9e126105e91/writeprotection-of-bookmarks-in-word?forum=vsto

我想要的是哪种。但无法实现/将其转换为VBA代码。有人也可以看到我可以使用它吗?

再次感谢。

编辑:office 2007/2010。

2 个答案:

答案 0 :(得分:13)

以下构思针对Word 2010进行了测试。它应该适用于2007年和2013年,但不适用于2003年。

我建议将ContentControls(在文中进一步称为CC)与Bookmarks一起使用。接下来,您需要控制一个事件,该事件将检查用户是否正在选择任何ContentControl内部。如果是这样,我们将在保护区外显示消息和/或移动选择。

第1步。您的每个书签都应该包含在 RichText ContentControl 中。您可以手动为选定的书签执行此操作,也可以运行以下简单代码对活动文档中的所有书签执行此操作。

重要假设!您的文档中没有任何其他ContentControls!)

Sub Add_Bookmark_CC()

    Dim bookM As Bookmark
    For Each bookM In ActiveDocument.Bookmarks
        ActiveDocument.ContentControls.add wdContentControlRichText, bookM.Range
    Next

End Sub

第二步。我们将控制一个事件:Document_ContentControlOnEnter。转到Document VBAProject中的ThisDocument模块并创建以下事件(请参阅代码中的一些注释):

Private Sub Document_ContentControlOnEnter(ByVal ContentControl As ContentControl)
    Debug.Print Now, ContentControl.Range.Bookmarks.Count

    If ContentControl.Range.Bookmarks.Count > 0 Then
        'Optional message box for user
        MsgBox "There is bookmark inside this area which you should not change. " & _
            vbNewLine & "You will be moved out of this range"

        'optionam selection change right after CC area
        Dim newPos As Long
            newPos = ContentControl.Range.End + 2
        ActiveDocument.Range(newPos, newPos).Select

    End If

End Sub

第1步和第2步的替代选择。如果您不想使用CC事件,可以使用CC内容保护为每个书签添加CC。在这种情况下,您只需要第一步和以下子步骤:

Sub Add_Bookmark_CC_Protected()

    Dim bookM As Bookmark
    Dim CC As ContentControl
    For Each bookM In ActiveDocument.Bookmarks
        Set CC = ActiveDocument.ContentControls.add(wdContentControlRichText, bookM.Range)
        CC.LockContents = True
    Next

End Sub

最终!正如您所看到的,步骤1和2有更多可能的组合。 如果您需要进行任何初始测试,以下代码允许您删除所有CC:

Sub Remove_All_CC()

    Dim CC As ContentControl
    For Each CC In ActiveDocument.ContentControls
        CC.Delete
    Next CC
End Sub

答案 1 :(得分:4)

使用

保护整个文档
'whole document readonly
ThisDocument.Protect Password:="password", NoReset:=False, Type:=wdAllowReadOnly

'only write in form fields (can't delete them, just fill them out)
ThisDocument.Protect Password:="mypassword", NoReset:=False, Type:=wdAllowOnlyFormFields

现在可以免费提供文档的某些部分进行编辑:

ThisDocument.Bookmarks("myBookmark").Range.Editors.Add wdEditorEveryone
Selection.Range.Editors.Add wdEditorEveryone

<小时/> <强>替代 (未经测试)

不保护整个文档,只限制要锁定的书签

ThisDocument.Bookmarks("myBookmark").Range.Editors.Add wdEditorOwners

ThisDocument.Bookmarks("myBookmark").Range.Editors.Add "abc@test.com"