Как получить поток для шаблона в библиотеке документов - PullRequest
1 голос
/ 02 апреля 2011

Я пытаюсь загрузить файл шаблона, установленный моим SPDocumentLibrary, выполнить некоторые преобразования в OpenXML, а затем сохранить его обратно в библиотеку как документ. Я думаю, что у меня есть все шаги, кроме чтения шаблона. Я не знаю «правильного» способа открыть его (я мог бы просто использовать WebClient для его загрузки, но я чувствую себя грязно, просто набирая его). Вот что у меня есть.

public string GetOrGenerateChecklist(string PracticeName, string ContractID, string EducationDate, string MainContactInfo, string Address)
{
    using (SPWeb web = SPContext.Current.Web)
    {
        SPDocumentLibrary list = (SPDocumentLibrary)web.Lists["Educator Checklists"];
        var templetAddr = String.Concat(web.Url, '/', list.DocumentTemplateUrl);
        SPQuery query = new SPQuery();
        query.Query = string.Concat(
                                //Snip
                                   );
        var items = list.GetItems(query);
        //if document exists return existing document.
        if (items.Count > 0)
            return String.Concat(web.Url, "/Educator Checklists/", PracticeName, " - ", ContractID, ".docx");

        MemoryStream documentStream;

        //copy the stream to memory
        using (Stream tplStream = ????????) //<-------   my problem
        {
            documentStream = new MemoryStream((int)tplStream.Length);
            CopyStream(tplStream, documentStream);
            documentStream.Position = 0L;
        }
        using (WordprocessingDocument template = WordprocessingDocument.Open(documentStream, true))
        {
            template.ChangeDocumentType(DocumentFormat.OpenXml.WordprocessingDocumentType.Document);
            MainDocumentPart mainPart = template.MainDocumentPart;
            mainPart.DocumentSettingsPart.AddExternalRelationship(
                "http://schemas.openxmlformats.org/officeDocument/2006/relationships/attachedTemplate",
                new Uri(templetAddr, UriKind.Absolute));

            ReplaceText(mainPart, "#PracticeName#", PracticeName);
            ReplaceText(mainPart, "#EducationDate#", EducationDate);
            ReplaceText(mainPart, "#MainContactInfo#", MainContactInfo);
            ReplaceText(mainPart, "#Address#", Address);
        }
        documentStream.Position = 0L;
        list.RootFolder.Files.Add(String.Concat(PracticeName, " - ", ContractID, ".docx"), documentStream);

        return String.Concat(web.Url, "/Educator Checklists/", PracticeName, " - ", ContractID, ".docx");
    }

}

Итак, мой вопрос, как мне получить шаблон, хранящийся в templetAddr, загруженный в поток памяти?

Кроме того, я довольно новичок в sharepoint, поэтому, если вы заметите какие-либо другие большие ошибки, которые я допустил, сообщите мне.

Ответы [ 2 ]

4 голосов
/ 02 апреля 2011
web.GetFile(templetAddr).OpenBinaryStream() 

http://msdn.microsoft.com/en-us/library/ms476063.aspx (SPWeb.GetFile)

http://msdn.microsoft.com/en-us/library/ms470901.aspx (SPFile.OpenBinaryStream)

1 голос
/ 16 мая 2011

Вот сообщение в блоге, в котором обсуждаются некоторые соображения, касающиеся использования объектной модели SharePoint для получения документа Open XML, его изменения и возврата.

http://blogs.msdn.com/b/ericwhite/archive/2010/03/24/modifying-an-open-xml-document-in-a-sharepoint-document-library.aspx

Вот самый маленький код для этого:

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading;
using Microsoft.SharePoint;
using DocumentFormat.OpenXml.Packaging;
using DocumentFormat.OpenXml.Wordprocessing;

class Program
{
    static void Main(string[] args)
    {
        string siteUrl = "http://localhost";
        using (SPSite spSite = new SPSite(siteUrl))
        {
            Console.WriteLine("Querying for Test.docx");
            SPList list = spSite.RootWeb.Lists["Shared Documents"];
            SPQuery query = new SPQuery();
            query.ViewFields = @"<FieldRef Name='FileLeafRef' />";
            query.Query =
              @"<Where>
                  <Eq>
                    <FieldRef Name='FileLeafRef' />
                    <Value Type='Text'>Test.docx</Value>
                  </Eq>
                </Where>";
            SPListItemCollection collection = list.GetItems(query);
            if (collection.Count != 1)
            {
                Console.WriteLine("Test.docx not found");
                Environment.Exit(0);
            }
            Console.WriteLine("Opening");
            SPFile file = collection[0].File;
            byte[] byteArray = file.OpenBinary();
            using (MemoryStream memStr = new MemoryStream())
            {
                memStr.Write(byteArray, 0, byteArray.Length);
                using (WordprocessingDocument wordDoc =
                    WordprocessingDocument.Open(memStr, true))
                {
                    Document document = wordDoc.MainDocumentPart.Document;
                    Paragraph firstParagraph = document.Body.Elements<Paragraph>()
                        .FirstOrDefault();
                    if (firstParagraph != null)
                    {
                        Paragraph testParagraph = new Paragraph(
                            new Run(
                                new Text("Test")));
                        firstParagraph.Parent.InsertBefore(testParagraph,
                            firstParagraph);
                    }
                }
                Console.WriteLine("Saving");
                string linkFileName = file.Item["LinkFilename"] as string;
                file.ParentFolder.Files.Add(linkFileName, memStr, true);
            }
        }
    }
}
...