開源Word讀寫組件DocX介紹與入門

jopen 9年前發布 | 21K 次閱讀 .NET開發 Docx

1.前言

讀寫Offic格式的文檔,大家多少都有用到,可能方法也很多,組件有很多。這里不去討論其他方法的優劣,只是向大家介紹一款開源的讀寫word文檔的組件。讀寫ExcelNPOI,讀寫Word,那看看DocX吧。

DocX是一個以非常直觀簡單的方式操作Word 2007/2010文件的輕量級.NET組件。它的速度非常快,而且不需要安裝微軟的Office軟件。在中國,免費并且小巧的WPS有足夠的理由讓很多用戶放棄龐大的Office,那在實際軟件開發過程中,這玩意就有用處了。遺憾是不支持2003,但總歸是被淘汰的趨勢,而且用WPS,也沒有啥版本的區別。

2.DocX的主要特點

DocX組件目前的最新版本是V1.0.0.12,主要特點有:

1.支持在文件中插入、刪除和替代文本,支持所有的文本格式,如字體,下劃線,高亮等。

2.支持插入圖片、超鏈接、表格、頁眉頁腳以及自定義屬性等。

3.支持類似JQuery的鏈式寫法,很方便編程開發。

3.DocX入門例子

 DocX中一個Word文檔的主要對象有段落(Paragraph)、圖像(Image)、表格(Table)、自定義屬性(CustomProperty)。關于詳細的使用和API接口,可以參考CHM文檔,沒有自己制作最新版的,我用的是上一個版本,基本使用夠了。有精力的可以自己去看源碼,自己制作一份。注意,無特殊注明,本文的絕大部分代碼都來自V1.0.0.10版本的幫助文檔,新的11和12版本好像沒有增加大的新功能,只是修改不少Bug,以及增加了案例和單元測試,至于沒有介紹到的,可以自己去翻文檔,大家可以去開源網站下載最新源碼。

 3.1 新建與加載Doc文檔 

新建和加載Word文檔的方法都在Docx類中,操作也很簡單,如下所示: 

 
//新建一個Word文檔,加載Load的方法和Create使用一樣。
using (DocX document = DocX.Create(@"..\Test.docx"))
{
    //添加一些基本對象,如段落等
    document.Save();//保存
}

 3.2 添加段落及控制格式

 文本段落和格式控制是Word文檔的最常用對象,DocX支持插入段落以及對段落格式進行很全面的控制。下面一一舉例。

插入段落的方法是DocX類的InsertParagraph方法,該方法有好幾種使用方法,不僅可以控制插入的位置,還可以控制格式。 

 
using (DocX document = DocX.Create(@"Test.docx"))
{
    //首先創建1個格式對象
    Formatting formatting = new Formatting();
    formatting.Bold = true;
    formatting.FontColor = Color.Red;
    formatting.Size = 30;
     //控制段落插入的位置
    int index = document.Text.Length / 2;
    //將文本插入到指定位置,并控制格式
    document.InsertParagraph(index, "New text", false, formatting);
    document.Save();//保存文檔
}

 注意,上面只是插入段落,也可以單獨定義1個段落對象Paragraph,然后在這個段落中插入表格,圖像,以及操作自定義屬性。如下面的例子,其中比較詳細介紹的對圖像的操作:

 
using (DocX document = DocX.Create(@"Test.docx"))
{
    //給文檔新建1個段落對象
    Paragraph p = document.InsertParagraph("Here is Picture 1", false);
    //給文檔添加1個圖像
    Novacode.Image img = document.AddImage(@"Image.jpg");
    //將圖像插入到段落后面
    Picture pic = p.InsertPicture(img.Id, "Photo 31415", "A pie I baked.");
    //選擇圖像,并修改圖像尺寸
    pic.Rotation = 30;    
    pic.Width = 400;
    pic.Height = 300;
    //設置圖片形狀,并水平翻轉圖片
    pic.SetPictureShape(BasicShapes.cube);
    pic.FlipHorizontal = true;    
    document.Save();//保存文檔
}

格式控制Formatting類全部是屬性,沒有方法。有很多控制格式的屬性,直接進行設置就可以了,暫時沒有發現這個版本支持樣式,所以只能定義1個全局格式來控制標題了。具體的格式控制可以去看該類的文檔。太多,不一一列舉,基本使用上面的代碼就可以說明了。

另外新版本已經支持了增加超鏈接(Hyperlink)功能,使用很簡單,DocX的AddHyperlink方法直接完成。

3.3 插入圖像及圖像控制

上面的例子其實已經介紹了幾種插入圖片的方式,一種是在DocX對象中直接AddImage,另外就是在段落中插入。其中3.2的例子已經很詳細介紹了圖像的控制,比如修改尺寸,旋轉等。更詳細的設置在Picture類中。

3.4 插入表格及表格控制

表格是Word文檔另外一個重點,在實際使用環境中,也是比例很高的一個。先介紹下DocX中表格對象的結構:

1個表格對象Table有行,列組成,行列可以通過索引訪問。Table對象的基本單一是單元格(Cell),每一個Row 對象由多個Cell對象組成,Cell對象有一個默認的Paragraph對象,這樣可以對這個Paragraph對象進行格式控制,從而控制單元格的格式。表格還可以設置相關屬性,對齊,是否自適應表格大小等。Table對象的操作也很靈活,可以插入和移除行,同樣也可以插入和移除列。

DocX對象插入表格也有幾種方式,可以直接用DocX對象的InsertTable方法,也可以在段落對象后面插入;同理也可以在Table對象前后插入段落對象,這與排版有關了。看1個綜合的例子吧:

3.5 頁眉頁腳控制

頁面和頁腳的使用非常類似。支持三種類型,首頁,奇數頁和偶數頁。貌似還沒有支持節。這里只列舉頁腳的基本使用。 

 
using (DocX document = DocX.Create(@"Test.docx")) 
{
    document.AddFooters();//添加所有的頁腳
    Footers footers = document.Footers; //獲取該文檔所有的頁腳
    //獲取文檔第一頁的頁腳
    Footer first = footers.first; 
    //獲取奇數頁的頁腳
    Footer odd = footers.odd; 
    //獲取偶數頁的頁腳
    even = footers.even; 
    //設置不同頁使用不同的頁腳
    document.DifferentFirstPage = true; 
    document.DifferentOddAndEvenPages = true; 
    //設置頁腳的內容
    Paragraph p = first.InsertParagraph();
    p.Append("This is the first pages footer.");    
    document.Save(); //記得保存
}

3.6 自定義屬性支持

雖然還沒有用DocX投入實際使用,但個人認為對自定義屬性的支持是最強大的1個功能,不僅可以自己制作模版,還可以直接在DocX中新增自定義屬性,這樣在導出大批量相同的格式的文檔時就很有用。比如打印成績單,報表等等。由于本人從沒有使用Word 2007及以上版本,所有也從沒有接觸過這個自定義屬性功能。我的理解,類似一個“占位標”或”文本控件”,然后在開發的時候,可以給這些位置填充值,以批量生成一些文件。下面只簡單的介紹一個直接添加自定義屬性,并賦值的例子,高級一點的話,可以自己更加細致的排版,這樣就美觀點。

 
using (DocX document = DocX.Load(@"C:\Example\Test.docx"))
{
    //先定義一個自定義屬性
    CustomProperty forename;
    //先判斷文檔中是否存在該名稱的自定義屬性
    if (!document.CustomProperties.ContainsKey("forename"))
    {    //不存在則創建一個,并給其賦值"Cathal"
        document.AddCustomProperty(new CustomProperty("forename", "Cathal"));
    }
    //獲取這個自定義屬性,并打印出它的值
    forename = document.CustomProperties["forename"];
    Console.WriteLine(string.Format("Name: '{0}', Value: '{1}'\nPress any key...", 
                        forename.Name, forename.Value));
    document.Save();
}

4.資源

開源網址:http://docx.codeplex.com/

來自:http://www.cnblogs.com/asxinyu/archive/2013/02/22/2921861.html

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!