C# 替换Word文档中的书签内容【详细步骤】
Word書簽不但可以幫助讀者快速跳轉到想要查看的位置,而且可以用做“占位符”,程序員獲取“占位符”之后,就可以更新這些“占位符”,即替換書簽內容。替換模板文檔中的書簽內容,可以幫助我們快速生成Word報表或文檔。
本文總結了一個將常見的Word文檔元素(文字、圖片和表格)替換進書簽的C#解決方案,具體步驟見下文。
使用工具:
- Spire.Doc.dll 6.4.5
- ?Visual Studio 2013
步驟一 制作模板
1.??新建Word文檔
圖1?創建文檔
2.? 插入書簽
圖2?插入書簽
3.??保存模板,命名為“bookmark_template.docx”
圖3?保存模板文檔
步驟二 在項目中添加引用
1.??右鍵點擊“解決方案資源管理”中的“引用”,選擇“添加引用”
圖4 添加引用
2.??選擇要引用的Spire.Doc.dll文件,添加至項目中
圖5 引用Spire.Doc.dll
步驟三 編碼
Spire.Doc提供了BookmarksNavigator類來獲取和操作文檔中的書簽,但方法不是很直觀。為了方便,我自己封裝了Bookmark類,其中包括RepalceContent及其2個重載方法來分別應對插入文字、圖片和表格三種情況。
- public TextRange ReplaceContent(string bookmarkName, string text, bool saveFormatting)
- public void ReplaceContent(string bookmarkName, string picPath, float widthScale, float heightScale, TextWrappingStyle wrapStyle, ShapeHorizontalAlignment horizontalAlignment)
- public void ReplaceContent(string bookmarkName, Table table)
第一部分:Bookmark.cs編碼
using Spire.Doc; using Spire.Doc.Fields; using System.Drawing; using Spire.Doc.Interface; using Spire.Doc.Documents;namespace ReplaceBookmarkContent {class Bookmark{private Document doc = null;public Bookmark(Document document){doc = document;}/// <summary>/// 用文本替換指定書簽的內容/// </summary>/// <param name="bookmarkName">書簽名</param>/// <param name="text">文本</param>/// <param name="saveFormatting">刪除原始書簽內容時,是否保留格式</param>/// <returns>TextRange</returns>public TextRange ReplaceContent(string bookmarkName, string text, bool saveFormatting){BookmarksNavigator navigator = new BookmarksNavigator(doc);navigator.MoveToBookmark(bookmarkName);//指向特定書簽navigator.DeleteBookmarkContent(saveFormatting);//刪除原有書簽內容 Spire.Doc.Interface.ITextRange textRange = navigator.InsertText(text);//寫入文本return textRange as TextRange;}/// <summary>/// 用圖片替換指定書簽的內容/// </summary>/// <param name="bookmarkName">書簽名</param>/// <param name="picPath">圖片路徑</param>/// <param name="widthScale">寬度縮放比例,0以上正整數</param>/// <param name="heightScale">高度縮放比例,0以上正整數</param>/// <param name="wrapStyle">環繞方式</param>/// <param name="horizontalAlignment"></param>public void ReplaceContent(string bookmarkName, string picPath, float widthScale, float heightScale, TextWrappingStyle wrapStyle, ShapeHorizontalAlignment horizontalAlignment){BookmarksNavigator navigator = new BookmarksNavigator(doc);navigator.MoveToBookmark(bookmarkName);navigator.DeleteBookmarkContent(false);IParagraphBase paragraphBase = navigator.InsertParagraphItem(ParagraphItemType.Picture);//插入類型為圖片Image image = Image.FromFile(picPath);//加載圖片DocPicture picture = paragraphBase.OwnerParagraph.AppendPicture(image);//插入圖片picture.WidthScale = widthScale;picture.HeightScale = heightScale;picture.TextWrappingStyle = wrapStyle;picture.HorizontalAlignment = horizontalAlignment;}/// <summary>/// 用表格替換指定書簽的內容/// </summary>/// <param name="bookmarkName">書簽名</param>/// <param name="table">Table實例</param>public void ReplaceContent(string bookmarkName, Table table){BookmarksNavigator navigator = new BookmarksNavigator(doc);navigator.MoveToBookmark(bookmarkName);TextBodyPart body = new TextBodyPart(doc);body.BodyItems.Add(table);navigator.ReplaceBookmarkContent(body);}/// <summary>/// 創建表格并寫入數據,返回Table對象/// </summary>/// <param name="rowsNum">行數</param>/// <param name="columnsNum">列數</param>/// <param name="columnWidth">列寬</param>/// <param name="horizontalAlignment">水平對齊方式</param>/// <param name="datatable">DataTable實例</param>/// <returns></returns>public Table CreateTable(int rowsNum, int columnsNum, float columnWidth, RowAlignment horizontalAlignment, System.Data.DataTable datatable){Table table = new Table(doc, true, 1f);//初始化Table對象table.ResetCells(rowsNum, columnsNum);//設置行數和列數//填充數據for (int i = 0; i < datatable.Rows.Count; i++){for (int j = 0; j < datatable.Columns.Count; j++){table.Rows[i].Cells[j].AddParagraph().AppendText(datatable.Rows[i][j].ToString());}}//設置列寬for (int i = 0; i < rowsNum; i++){for (int j = 0; j < columnsNum; j++){table.Rows[i].Cells[j].Width = columnWidth;} }table.TableFormat.HorizontalAlignment = horizontalAlignment;//表格水平對齊方式return table;}} }第二步部分:生成文件的編碼
//加載模板文檔 Document doc = new Document(); doc.LoadFromFile(@"C:\Users\Administrator\Desktop\bookmark_template.docx");//初始化Bookmark對象 Bookmark bookmark = new Bookmark(doc);//用文本替換書簽bookmark_text的內容 string text = "XXX科技股份有限公司成立于2010年12月,是一家致力于高新技術產品研發、生產、銷售的高科技股份制企業,"+ "公司堅持以技術創新為核心,以知識產權為基礎,以人才戰略為支撐,經過多年的礪練與發展,公司已逐步成以創新為引導的,"+ "產品具有競爭力,人才素質優良的新興科技企業。"; bookmark.ReplaceContent("bookmark_text", text, true);//用圖片替換書簽bookmark_picture的內容 string picPath = @"C:\Users\Administrator\Desktop\company_logo.jpg"; bookmark.ReplaceContent("bookmark_picture", picPath, 80f, 80f, TextWrappingStyle.TopAndBottom, ShapeHorizontalAlignment.Center);//創建模擬數據 DataTable dt = new DataTable(); dt.Columns.Add("employee_id", typeof(string)); dt.Columns.Add("name", typeof(string)); dt.Columns.Add("age", typeof(string)); dt.Columns.Add("sex", typeof(string)); dt.Columns.Add("title", typeof(string)); dt.Rows.Add(new string[] {"工號", "姓名", "年齡", "性別", "職位" }); dt.Rows.Add(new string[] {"1023","Nancy", "28", "女", "Java程序員" }); dt.Rows.Add(new string[] { "1024","James", "34", "男", ".NET程序員" }); dt.Rows.Add(new string[] { "1025","Kobe", "38", "男", "系統管理員" });//創建表格,并填充數據 Table table = bookmark.CreateTable(dt.Rows.Count, dt.Columns.Count, 100f, RowAlignment.Left, dt);//用表格替換書簽bookmark_table的內容 bookmark.ReplaceContent("bookmark_table", table);//生成Word文件 doc.SaveToFile("output.docx", FileFormat.Docx2013);運行代碼,得到下面的結果:
注:
1. Spire.Doc本身也有Bookmark類,但僅用于添加書簽到文檔中,請注意本文中的Bookmark類是自定義的方便自己使用的方法的集合。
2.??Spire.Doc 6.4.5 為商業版,在不應用許可證的情況下,生成的文檔會有水印信息。筆者寫文章時已應用臨時許可證(官方提供的用于測試軟件的License)。
3.??筆者使用免費版的Spire.Doc測試過,以上效果基本都能實現,但圖片的環繞方式只能設置為“InLine”,且水平位置為靠右,設置其他環繞方式時,圖片位置會出錯。這應該是免費版的Bug。
(原創內容,轉載請注明出處)
總結
以上是生活随笔為你收集整理的C# 替换Word文档中的书签内容【详细步骤】的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JS散度(Jensen-Shannon)
- 下一篇: C# 一个基于.NET Core3.1的