我们经常需要比较两个MS Word DOC / DOCX文档以检查相似性或差异。通过比较,我们可以了解在单个Word文档的两个版本中所做的更改。可以使用各种在线文档比较应用程序来比较两个Word文档。
- 比较两个Word(DOC / DOCX)文档
- 以DOCX格式下载比较结果
- 以PDF格式下载比较结果
Aspose.Words for .NET是一种高级Word文档处理API,用于执行各种文档管理和操作任务。API支持生成,修改,转换,呈现和打印文档,而无需在跨平台应用程序中直接使用Microsoft Word。此外,API支持所有流行的Word处理文件格式,并允许将Word文档导出或转换为固定布局文件格式和最常用的图像/多媒体格式。
>>Aspose.Words for .NET已经更新至v20.7,添加了新节点以处理多节结构化文档标签,改进了SmartArt冷渲染的性能,RevisionOptions类扩展了新的属性,体验
比较C#ASP.NET中的两个Word文档
在Visual Studio 2017或更高版本中创建新的ASP.NET Core Web应用程序。

选择 Web应用程序(模型-视图-控制器) 模板。

使用NuGet软件包管理器安装 Aspose.Words for .NET软件包。

将以下脚本复制并粘贴到 index.cshtml 视图中。
@{ ViewData["Title"] = "MS Word Comparison in ASP.NET";}<h2 class="text-info">Compare Two Word DOC/DOCX Documents</h2><p class="text-info">Compare the contents of MS Word documents and get the results in DOCX or PDF format.</p><br /><form asp-controller="Home" asp-action="UploadFiles" method="post" class="form-inline dropzone" enctype="multipart/form-data"> <div class="row"> <div class="col-md-6" align="center"> <div class="form-group"> <input type="file" id="input-id" name="files" accept=".doc, .docx" class="form-control file" data-preview-file-type="text" /> </div> </div> <div class="col-md-6" align="center"> <div class="form-group"> <input type="file" id="input-id2" name="files" accept=".doc, .docx" class="form-control file" /> </div> </div> </div> <br /> <div class="row"> <div class="col-md-12" align="center"> <div class="form-group"> <p class="text-info"> <strong>Output format:</strong> <select name="outputFormat" class="form-control"> <option value="DOCX">DOCX</option> <option value="PDF">PDF</option> </select> </p> </div> <div class="col-md-12" align="center"> <div class="form-group"> <button type="submit" class="form-control btn btn-success">Compare and Download</button> </div> </div> </div> </div></form><script> // Drag and drop plugin options $("#input-id").fileinput({ 'showUpload': false, 'previewFileType': 'any', 'showClose': false }); $("#input-id2").fileinput({ 'showUpload': false, 'previewFileType': 'any', 'showClose': false });</script>
将以下方法复制并粘贴到HomeController.cs控制器中。
[HttpPost]public FileResult UploadFiles(List<IFormFile> files, string outputFormat){if(files.Count()==0){return null;}string fileName = "result.docx";// Upload filesvar file1 = Path.Combine("wwwroot/uploads", files[0].FileName);var file2 = Path.Combine("wwwroot/uploads", files[1].FileName);using (var stream = new FileStream(file1, FileMode.Create)){files[0].CopyTo(stream);}using (var stream = new FileStream(file2, FileMode.Create)){files[1].CopyTo(stream);}// Load Word documentsDocument doc1 = new Document(file1);Document doc2 = new Document(file2);// Set comparison featuresCompareOptions compareOptions = new CompareOptions();compareOptions.IgnoreFormatting = true;compareOptions.IgnoreCaseChanges = true;compareOptions.IgnoreComments = true;compareOptions.IgnoreTables = true;compareOptions.IgnoreFields = true;compareOptions.IgnoreFootnotes = true;compareOptions.IgnoreTextboxes = true;compareOptions.IgnoreHeadersAndFooters = true;compareOptions.Target = ComparisonTargetType.New;var outputStream = new MemoryStream();// Compare Word documentsdoc1.Compare(doc2, "John Doe", DateTime.Now, compareOptions);if (outputFormat == "DOCX"){// For comparison result in DOCXdoc1.Save(outputStream, SaveFormat.Docx);outputStream.Position = 0;// Return generated Word filereturn File(outputStream, System.Net.Mime.MediaTypeNames.Application.Rtf, fileName);}else{// For comparison result in PDFfileName = "result.pdf";doc1.Save(outputStream, SaveFormat.Pdf);outputStream.Position = 0;// Return generated PDF filereturn File(outputStream, System.Net.Mime.MediaTypeNames.Application.Pdf, fileName);} }
将以下拖放插件的CSS和JS文件插入_layout.cshtml视图的head标签中。
<!--drag and drop file plugin--><link href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-fileinput/5.0.9/css/fileinput.min.css" media="all" rel="stylesheet" type="text/css" /><script src="https://code.jquery.com/jquery-3.3.1.min.js" crossorigin="anonymous"></script><script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.bundle.min.js" crossorigin="anonymous"></script><script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-fileinput/5.0.9/js/fileinput.min.js"></script><!--end of drag and drop-->
还想要更多吗可以点击阅读【2020 · Aspose最新资源整合】,查找需要的教程资源。如果您有任何疑问或需求,请随时加入Aspose技术交流群(),我们很高兴为您提供查询和咨询。
标签:
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!