翻譯|使用教程|編輯:李顯亮|2020-07-08 11:46:15.147|閱讀 297 次
概述:我們經常需要比較兩個MS Word DOC / DOCX文檔以檢查相似性或差異。在本文中,將展示如何在ASP.NET Web應用程序中使用C#比較兩個Word文檔。
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
我們經常需要比較兩個MS Word DOC / DOCX文檔以檢查相似性或差異。通過比較,我們可以了解在單個Word文檔的兩個版本中所做的更改。可以使用各種在線文檔比較應用程序來比較兩個Word文檔。
但是,在某些情況下,需要在Web應用程序中集成文檔比較功能。另一方面,可能要構建自己的在線文檔比較應用程序。為了解決這種情況,本文將展示如何在ASP.NET Web應用程序中使用C#比較兩個Word文檔。此應用程序將具有以下功能:
Aspose.Words for .NET是一種高級Word文檔處理API,用于執行各種文檔管理和操作任務。API支持生成,修改,轉換,呈現和打印文檔,而無需在跨平臺應用程序中直接使用Microsoft Word。此外,API支持所有流行的Word處理文件格式,并允許將Word文檔導出或轉換為固定布局文件格式和最常用的圖像/多媒體格式。
>>Aspose.Words for .NET已經更新至v20.7,添加了新節點以處理多節結構化文檔標簽,改進了SmartArt冷渲染的性能,RevisionOptions類擴展了新的屬性,點擊下載體驗
在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 files var 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 documents Document doc1 = new Document(file1); Document doc2 = new Document(file2); // Set comparison features CompareOptions 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 documents doc1.Compare(doc2, "John Doe", DateTime.Now, compareOptions); if (outputFormat == "DOCX") { // For comparison result in DOCX doc1.Save(outputStream, SaveFormat.Docx); outputStream.Position = 0; // Return generated Word file return File(outputStream, System.Net.Mime.MediaTypeNames.Application.Rtf, fileName); } else { // For comparison result in PDF fileName = "result.pdf"; doc1.Save(outputStream, SaveFormat.Pdf); outputStream.Position = 0; // Return generated PDF file return File(outputStream, System.Net.Mime.MediaTypeNames.Application.Pdf, fileName); } }
將以下拖放插件的CSS和JS文件插入_layout.cshtml視圖的head標簽中。
<!--drag and drop file plugin--> <link media="all" rel="stylesheet" type="text/css" /> <script src="http://code.jquery.com/jquery-3.3.1.min.js" crossorigin="anonymous"></script> <script src="http://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.bundle.min.js" crossorigin="anonymous"></script> <script src="http://cdnjs.cloudflare.com/ajax/libs/bootstrap-fileinput/5.0.9/js/fileinput.min.js"></script> <!--end of drag and drop-->
本站文章除注明轉載外,均為本站原創或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn