[英]OpenXml Dotx to Docx Word Found Unreadable Content
我正在尝试编写代码来填充模板的内容控件,然后将其保存为新文件。
我发现这个非常有用的条目Word OpenXml Word 找到了不可读的内容并在那里使用了代码。
我从该帖子中复制了代码,如下所示
public static MemoryStream ReadAllBytesToMemoryStream(string path)
{
byte[] buffer = File.ReadAllBytes(path);
var destStream = new MemoryStream(buffer.Length);
destStream.Write(buffer, 0, buffer.Length);
destStream.Seek(0, SeekOrigin.Begin);
return destStream;
}
public static void Generate()
{
using MemoryStream stream = ReadAllBytesToMemoryStream(@"c:\Templates\TemplateTest.dotx");
using (WordprocessingDocument wpd = WordprocessingDocument.Open(stream, true))
{
wpd.ChangeDocumentType(WordprocessingDocumentType.Document);
}
File.WriteAllBytes(@"c:\Templates\TemplateTestOutput.docx", stream.GetBuffer());
return;
}
它成功地创建了文件,但问题是,每当我打开新的 docx 文件时,它都会出现“Word Found Unreadable Content”错误。 我制作的模板并不复杂,它只有 3 个带有常规标签文本的内容控件。 我还尝试使用仅几行文本复制常规 docx,同样的错误。
每当我单击确定时,在 Word Found Unreadable Content 错误上,它显示文档就好了。 我不确定自己做错了什么,此时我什至没有编辑任何内容。
想出了一个解决办法。
而不是使用 File.WriteAllBytes
File.WriteAllBytes(@"C:\\Templates\TemplateTestOutput.docx", stream.GetBuffer());
我使用了以下代码:
using (FileStream fileStream = new FileStream(@"C:\\Templates\TemplateTestOutput.docx", System.IO.FileMode.CreateNew))
{
stream.WriteTo(fileStream);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.