開源Word讀寫組件DocX介紹與入門
今天向大家介紹一款.NET下的開源輕量級Word 2007/2010格式讀寫組件DocX,很小巧,能夠滿足大部分工作需求吧,最重要的是可以不用龐大的Office。
1.前言
讀寫Offic格式的文檔,大家多少都有用到,可能方法也很多,組件有很多。這里不去討論其他方法的優(yōu)劣,只是向大家介紹一款開源的讀寫word文檔的組件。讀寫Excel有NPOI,讀寫Word,那看看DocX吧。
DocX是一個以非常直觀簡單的方式操作Word 2007/2010文件的輕量級.NET組件。它的速度非???,而且不需要安裝微軟的Office軟件。在中國,免費并且小巧的WPS有足夠的理由讓很多用戶放棄龐大的Office,那在實際軟件開發(fā)過程中,這玩意就有用處了。遺憾是不支持2003,但總歸是被淘汰的趨勢,而且用WPS,也沒有啥版本的區(qū)別。
2.DocX的主要特點
DocX組件目前的最新版本是V1.0.0.12,主要特點有:
1.支持在文件中插入、刪除和替代文本,支持所有的文本格式,如字體,下劃線,高亮等。
2.支持插入圖片、超鏈接、表格、頁眉頁腳以及自定義屬性等。
3.支持類似JQuery的鏈式寫法,很方便編程開發(fā)。
3.DocX入門例子
DocX中一個Word文檔的主要對象有段落(Paragraph)、圖像(Image)、表格(Table)、自定義屬性(CustomProperty)。關(guān)于詳細的使用和API接口,可以參考CHM文檔,沒有自己制作最新版的,我用的是上一個版本,基本使用夠了。有精力的可以自己去看源碼,自己制作一份。注意,無特殊注明,本文的絕大部分代碼都來自V1.0.0.10版本的幫助文檔,新的11和12版本好像沒有增加大的新功能,只是修改不少Bug,以及增加了案例和單元測試,至于沒有介紹到的,可以自己去翻文檔,大家可以去開源網(wǎng)站下載最新源碼。
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"))
- {
- //首先創(chuàng)建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;
- //設(shè)置圖片形狀,并水平翻轉(zhuǎn)圖片
- pic.SetPictureShape(BasicShapes.cube);
- pic.FlipHorizontal = true;
- document.Save();//保存文檔
- }
格式控制Formatting類全部是屬性,沒有方法。有很多控制格式的屬性,直接進行設(shè)置就可以了,暫時沒有發(fā)現(xiàn)這個版本支持樣式,所以只能定義1個全局格式來控制標(biāo)題了。具體的格式控制可以去看該類的文檔。太多,不一一列舉,基本使用上面的代碼就可以說明了。
另外新版本已經(jīng)支持了增加超鏈接(Hyperlink)功能,使用很簡單,DocX的AddHyperlink方法直接完成。
3.3 插入圖像及圖像控制
上面的例子其實已經(jīng)介紹了幾種插入圖片的方式,一種是在DocX對象中直接AddImage,另外就是在段落中插入。其中3.2的例子已經(jīng)很詳細介紹了圖像的控制,比如修改尺寸,旋轉(zhuǎn)等。更詳細的設(shè)置在Picture類中。
3.4 插入表格及表格控制
表格是Word文檔另外一個重點,在實際使用環(huán)境中,也是比例很高的一個。先介紹下DocX中表格對象的結(jié)構(gòu):
1個表格對象Table有行,列組成,行列可以通過索引訪問。Table對象的基本單一是單元格(Cell),每一個Row對象由多個Cell對象組成,Cell對象有一個默認的Paragraph對象,這樣可以對這個Paragraph對象進行格式控制,從而控制單元格的格式。表格還可以設(shè)置相關(guān)屬性,對齊,是否自適應(yīng)表格大小等。Table對象的操作也很靈活,可以插入和移除行,同樣也可以插入和移除列。
DocX對象插入表格也有幾種方式,可以直接用DocX對象的InsertTable方法,也可以在段落對象后面插入;同理也可以在Table對象前后插入段落對象,這與排版有關(guān)了???個綜合的例子吧:
3.5 頁眉頁腳控制
頁面和頁腳的使用非常類似。支持三種類型,首頁,奇數(shù)頁和偶數(shù)頁。貌似還沒有支持節(jié)。這里只列舉頁腳的基本使用。
- using (DocX document = DocX.Create(@"Test.docx"))
- {
- document.AddFooters();//添加所有的頁腳
- Footers footers = document.Footers; //獲取該文檔所有的頁腳
- //獲取文檔第一頁的頁腳
- Footer first = footers.first;
- //獲取奇數(shù)頁的頁腳
- Footer odd = footers.odd;
- //獲取偶數(shù)頁的頁腳
- even = footers.even;
- //設(shè)置不同頁使用不同的頁腳
- document.DifferentFirstPage = true;
- document.DifferentOddAndEvenPages = true;
- //設(shè)置頁腳的內(nèi)容
- Paragraph p = first.InsertParagraph();
- p.Append("This is the first pages footer.");
- document.Save(); //記得保存
- }
3.6 自定義屬性支持
雖然還沒有用DocX投入實際使用,但個人認為對自定義屬性的支持是最強大的1個功能,不僅可以自己制作模版,還可以直接在DocX中新增自定義屬性,這樣在導(dǎo)出大批量相同的格式的文檔時就很有用。比如打印成績單,報表等等。由于本人從沒有使用Word 2007及以上版本,所有也從沒有接觸過這個自定義屬性功能。我的理解,類似一個“占位標(biāo)”或”文本控件”,然后在開發(fā)的時候,可以給這些位置填充值,以批量生成一些文件。下面只簡單的介紹一個直接添加自定義屬性,并賦值的例子,高級一點的話,可以自己更加細致的排版,這樣就美觀點。
- using (DocX document = DocX.Load(@"C:\Example\Test.docx"))
- {
- //先定義一個自定義屬性
- CustomProperty forename;
- //先判斷文檔中是否存在該名稱的自定義屬性
- if (!document.CustomProperties.ContainsKey("forename"))
- { //不存在則創(chuàng)建一個,并給其賦值"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.資源
開源網(wǎng)址:http://docx.codeplex.com/
原文鏈接:http://www.cnblogs.com/asxinyu/archive/2013/02/22/2921861.html