C#限制编辑部分字段

时间:2016-09-07 07:38:44

标签: c# ms-word vsto

允许用户编辑黄色段落。 但我得到这个文件: wrong document

我使用word限制编辑功能,我的代码是:

//写入段落
foreach (TaskChaptersModel chapter in listChapter)
{
    paragraph = doc.Content.Paragraphs.Add();
    paragraph.Range.Text = chapter.chapterNo + " " + chapter.chapterName;

    //标题1
    if (!chapter.chapterNo.Contains("."))
    {
        paragraph.Range.Font.Name = "宋体";//宋体
        paragraph.Range.Font.Bold = 2;//加粗
        paragraph.Range.Font.Size = 16;//三号
        paragraph.Range.ParagraphFormat.Alignment = Word.WdParagraphAlignment.wdAlignParagraphCenter;//水平居中
    }
    else if (chapter.chapterNo.Select(c => c == '.').Count() == 1)
    {
        paragraph.Range.Font.Name = "宋体";//宋体
        paragraph.Range.Font.Bold = 2;//加粗
        paragraph.Range.Font.Size = 16;//三号
        paragraph.Range.ParagraphFormat.Alignment = Word.WdParagraphAlignment.wdAlignParagraphLeft;//左对齐
        paragraph.Format.LineSpacingRule = Word.WdLineSpacing.wdLineSpace1pt5;
    }
    else
    {
        paragraph.Range.Font.Name = "宋体";//宋体
        paragraph.Range.Font.Size = 12;//三号
        paragraph.Range.ParagraphFormat.Alignment = Word.WdParagraphAlignment.wdAlignParagraphLeft;//左对齐
        paragraph.Format.LineSpacingRule = Word.WdLineSpacing.wdLineSpace1pt5;
    }
    paragraph.Range.InsertParagraphAfter();

    //-------------------------------------------------------------------
    //This paragraph alow edit
    paragraph = doc.Content.Paragraphs.Add();
    paragraph.Range.Text = "请您编辑,张三";
    paragraph.Range.Editors.Add(Word.WdEditorType.wdEditorEveryone);
    paragraph.Range.InsertParagraphAfter();                      
    //-------------------------------------------------------------------   
}

doc.Protect(Word.WdProtectionType.wdAllowOnlyReading, false, "000", false, true);

我的想法是在指定段落添加编辑器。

2 个答案:

答案 0 :(得分:1)

你的想法是正确的,但是Word的行为有点不同于预期。我注意到,就像你一样,无论添加新的段落,即使你没有专门为新段落添加编辑器,也可以编辑新的段落。

因此,您需要通过将所有人添加到完整文档中并通过从要保护的部分中删除编辑器来反过来解决它。

为了让您了解我创建了一小段VBA代码,但我确信您可以在C#中重写所需的部分。另请注意,我遍历编辑器,单独删除它们而不是使用DeleteAll()。我发现使用DeleteAll会引发意外的异常。

Sub TestRestrictDocument()

    If ActiveDocument.ProtectionType <> wdNoProtection Then
        ActiveDocument.Unprotect "000"
    End If

    ActiveDocument.Content.Editors.Add Word.WdEditorType.wdEditorEveryone

    Dim paragraph As paragraph

    For I = 1 To 5

        Set paragraph = ActiveDocument.Paragraphs(I)

        If I <> 4 Then
            paragraph.Range.Select

            Dim objEditor As Editor

            If Selection.Editors.Count > 0 Then
                For X = 1 To Selection.Editors.Count
                    Selection.Editors(X).Delete
                Next
            End If
        End If

    Next

    ActiveDocument.Protect Word.WdProtectionType.wdAllowOnlyReading, False, "000", False, True

End Sub

此示例向您显示(我创建了一个包含5个段落的文档进行测试),但可以编辑第四个段落。显然,您可以动态创建文档并删除其上的编辑器。

有些注意事项请记住,我遇到了这可能会有所帮助:

  • 始终检查您的文档是否已受到保护
  • 始终测试范围是否有要删除的编辑
  • 出于某种原因避免在编辑器上删除所有

答案 1 :(得分:0)

知道了: 1,创建doc 2,循环所有段落在右段添加编辑器 我发现在创建文档时我无法添加编辑器。

//写入段落

foreach (TaskChaptersModel chapter in listChapter)
{
    if (chapter.chapterNo == null || chapter.chapterNo == "-1")
    {
        continue;
    }

    paragraph = doc.Content.Paragraphs.Add();
    paragraph.Range.Text = chapter.chapterNo + " " + chapter.chapterName;

    //标题1
    if (!chapter.chapterNo.Contains("."))
    {
        paragraph.Range.Font.Name = "宋体";//宋体
        paragraph.Range.Font.Bold = 2;//加粗
        paragraph.Range.Font.Size = 16;//三号
        paragraph.Range.ParagraphFormat.Alignment = Word.WdParagraphAlignment.wdAlignParagraphCenter;//水平居中
    }
    else if (chapter.chapterNo.Select(c => c == '.').Count() == 1)
    {
        paragraph.Range.Font.Name = "宋体";//宋体
        paragraph.Range.Font.Bold = 2;//加粗
        paragraph.Range.Font.Size = 16;//三号
        paragraph.Range.ParagraphFormat.Alignment = Word.WdParagraphAlignment.wdAlignParagraphLeft;//左对齐
        paragraph.Format.LineSpacingRule = Word.WdLineSpacing.wdLineSpace1pt5;
    }
    else
    {
        paragraph.Range.Font.Name = "宋体";//宋体
        paragraph.Range.Font.Size = 12;//三号
        paragraph.Range.ParagraphFormat.Alignment = Word.WdParagraphAlignment.wdAlignParagraphLeft;//左对齐
        paragraph.Format.LineSpacingRule = Word.WdLineSpacing.wdLineSpace1pt5;
    }

    paragraph.Range.InsertParagraphAfter();
    paragraph = doc.Content.Paragraphs.Add();                                     
    //有编辑权限
    if (chapter.wordFlag == "E")
    {
        paragraph.Range.Text = "请您编辑," + userName;                        
    }
    else
    {
        paragraph.Range.HighlightColorIndex = Word.WdColorIndex.wdGray25;
    }
    paragraph.Range.InsertParagraphAfter();
}

foreach (Word.Paragraph p in doc.Paragraphs)
{
    if (p.Range.Text.Contains("请您编辑"))
    {
        p.Range.Select();
        p.Range.Editors.Add(Word.WdEditorType.wdEditorEveryone);
    }
}