У меня есть 2 фрагмента кода, которые работают по-разному
using (WordprocessingDocument wordDocument =
WordprocessingDocument.Create(@"D:\Tests\WordML\ML_Example.docx", WordprocessingDocumentType.Document))
{
// Add a main document part.
MainDocumentPart mainPart = wordDocument.AddMainDocumentPart();
TextReader tr = new StreamReader("SimpleTextExample.xml");
mainPart.Document = new Document(tr.ReadToEnd());
}
Здесь он отлично работает и генерирует .docx хорошо.
Теперь второй способ сделать это с помощью байтов и MemoryStream-uri.
MemoryStream modeleRootStream = new MemoryStream();
XmlWriterSettings writerSettings = new XmlWriterSettings
{
OmitXmlDeclaration = true
};
XmlWriter xmlWriter = XmlWriter.Create (modeleRootStream, writerSettings);
initialXml.WriteTo(xmlWriter);
xmlWriter.Flush();
modeleRootStream.Position = 0;
MemoryStream streamWithWord = new MemoryStream();
using (WordprocessingDocument wordDocument = WordprocessingDocument.Create(streamWithWord,
WordprocessingDocumentType.Document))
{
// Add a main document part.
MainDocumentPart mainPart = wordDocument.AddMainDocumentPart();
string streamContent = string.Empty;
using (StreamReader reader = new StreamReader(modeleRootStream))
{
streamContent = reader.ReadToEnd();
}
mainPart.Document = new Document(streamContent);
}
byte[] wordDocBytes = streamWithWord.GetBuffer();
streamWithWord.Close();
File.WriteAllBytes(@"D:\Tests\WordML\ML_Example1.docx", wordDocBytes);
Когда вы делаете это вторым способом, сгенерированный документ не подходит. В его document.xml вы увидите объявление xml. InitialXml представляет XElement исходного WordML xml.
<?xml version="1.0" encoding="utf-8"?><w:document xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main">
....
И когда вы пытаетесь открыть его в Word, выдается сообщение о том, что файл обрезан.
Как я могу использовать байты и MemoryStreams и не иметь этой проблемы.