0

我是 OpenXML 的新手,我将在这个问题上大发雷霆。帮助将不胜感激。

概述是我正在尝试通过 asp.net 填写 word 文档内容模板。

我可以轻松地使用 CustomXML 填充字段,但我尝试填充的文档也映射到 SharePoint 文档库。因此,当我在 SharePoint 库中上传文档时,它会自动填充 Word 文档内容控件中的列。现在使用自定义 XML 正在破坏该设置。当控件映射到 SharePoint 时,使用 OpenXML 填充数据不起作用。

请帮助示例代码或正确的方向。

4

1 回答 1

0

这正是我们在项目中所做的:)你很幸运。

首先,您需要为该文档库创建事件接收器。并且您需要实现 ItemUpdated 和 ItemAdded。请参阅 http://www.dotnetcurry.com/ShowArticle.aspx?ID=649 http://blogs.msdn.com/b/brianwilson/archive/2007/03/05/part-1-event-handlers-everything-你需要知道的关于微软办公室共享点门户服务器苔藓事件处理程序.aspx

//事件接收器的代码。这将为您提供内容控件的名称及其值

 Dictionary<string, string> results = new Dictionary<string, string>();
            using (Stream stream = file.OpenBinaryStream(SPOpenBinaryOptions.SkipVirusScan)) {

                using (WordprocessingDocument doc = WordprocessingDocument.Open(stream, true)) {
                    var contentControls = doc.MainDocumentPart
                        .GetXDocument()
                        .Descendants(w + "sdt");

                    foreach ( var contentControl in contentControls ) 
                    {
                        string key = (string)contentControl.Descendants(w + "sdtPr").Elements(w + "alias").Attributes(w + "val").FirstOrDefault();
                        string val = GetTextFromContentControl(contentControl);
                        results[key] = val;
                    }

 }

static string GetTextFromContentControl(XElement contentControlNode) {
            return contentControlNode.Descendants(w + "p")
                .Select
                (
                    p => p.Elements()
                          .Where(z => z.Name == r || z.Name == ins || z.Name == br)
                          .Descendants()
                          .Where(z => z.Name == w + "t" || z.Name == w + "br")
                          .StringConcatenate(element => (string)element + (element.Name == w + "br" ? Environment.NewLine : "")) + Environment.NewLine
                ).StringConcatenate();
        }
于 2012-08-09T00:06:47.233 回答