報(bào)表設(shè)計(jì)器開發(fā)_第1頁(yè)
報(bào)表設(shè)計(jì)器開發(fā)_第2頁(yè)
報(bào)表設(shè)計(jì)器開發(fā)_第3頁(yè)
報(bào)表設(shè)計(jì)器開發(fā)_第4頁(yè)
報(bào)表設(shè)計(jì)器開發(fā)_第5頁(yè)
已閱讀5頁(yè),還剩80頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

報(bào)表設(shè)計(jì)器開發(fā)摘要現(xiàn)在是信息社會(huì),各種信息都需要處理并直觀展現(xiàn),如股票,物價(jià)等信息都需要通過(guò)數(shù)據(jù)報(bào)表來(lái)展現(xiàn)、分析,因此高質(zhì)量報(bào)表軟件系統(tǒng)具有重要的實(shí)際意義。本論文課題研究探索了報(bào)表系統(tǒng)的開發(fā)方法與技術(shù),綜合應(yīng)用Eclipse、JAVA、JDBC、SWT/Jface、RCP、XML、CSS、DOM4J,IText,POI等先進(jìn)技術(shù),開發(fā)了基于WEB環(huán)境運(yùn)行的報(bào)表設(shè)計(jì)器,實(shí)現(xiàn)了報(bào)表設(shè)計(jì)、模板生成、報(bào)表編輯,報(bào)表發(fā)布等基本功能,為進(jìn)一步開發(fā)實(shí)用的報(bào)表系統(tǒng)奠定了基礎(chǔ)。關(guān)鍵詞:報(bào)表,SWT/Jface,Eclipse,XML,B/S,RCPAbstractNowistheinformationsociety,allkindsofinformationneedtobeaddressedandvisualdisplay,suchasstock,pricesandotherinformationneededtodemonstratethroughdatareports,analysis,thestatementsofhigh-qualitysoftwaresystemhasimportantpracticalsignificance.Thispaperstatementssubjecttostudyandexplorethesystemdevelopmentmethodsandtechnology,comprehensiveapplicationofEclipse,JAVA,JDBC,SWT/Jface,RCP,XML,CSS,DOM4J,IText,POI,andotheradvancedtechnology,thedevelopmentoftheoperatingenvironmentbasedonthestatementsWEBdesign,Achievedareportdesign,templategeneration,editingstatements,issuedstatementsofsuchbasicfunctions,forthefurtherdevelopmentofpracticalsystemlaidthefoundationforstatements.KEYWORDS:Report,SWT/JFace、Eclipse、XML、B/S、RCP目錄第一章概述 11.1課題背景與意義 11.2報(bào)表系統(tǒng)發(fā)展概況 2第二章開發(fā)技術(shù)及環(huán)境 42.1軟件環(huán)境 42.2主要開發(fā)技術(shù) 4第三章系統(tǒng)設(shè)計(jì) 63.1系統(tǒng)體系結(jié)構(gòu) 63.2軟件模塊結(jié)構(gòu) 73.3數(shù)據(jù)源與系統(tǒng)文件結(jié)構(gòu) 83.3.1系統(tǒng)數(shù)據(jù)源 83.3.2系統(tǒng)文件結(jié)構(gòu) 93.3.3報(bào)表顯示部分文件 13第四章系統(tǒng)實(shí)現(xiàn) 144.1主要實(shí)現(xiàn)算法 144.1.1新建報(bào)表流程圖 144.1.2新建數(shù)據(jù)源流程圖 154.1.3編輯單元格流程圖 164.1.4保存報(bào)表流程圖 174.1.5生成電子表格流程圖 184.1.6發(fā)布報(bào)表流程圖 204.1.7編輯CSS流程圖 214.1.8生成模板流程圖 224.1.9配置服務(wù)器流程圖 234.2系統(tǒng)編碼實(shí)現(xiàn) 234.2.1系統(tǒng)的主界面實(shí)現(xiàn) 234.2.2新建數(shù)據(jù)源 324.2.3新建報(bào)表 344.2.4編輯單元格 354.2.5生成電子表格 364.2.6發(fā)布報(bào)表 404.2.7編輯CSS 424.2.8生成模板 444.2.9報(bào)表保存 454.2.10配置服務(wù)器 48第五章系統(tǒng)典型界面 515.1系統(tǒng)主界面 515.1.1編輯視圖界面 525.1.2屬性視圖界面 525.1.3服務(wù)器視圖界面 535.1.4數(shù)據(jù)源視圖界面 535.2部分功能界面 545.2.1新建報(bào)表界面 545.2.2新建數(shù)據(jù)源界面 555.2.3設(shè)置CSS界面 565.2.4設(shè)置服務(wù)器參數(shù)界面 575.2.5設(shè)置報(bào)表參數(shù)界面 585.2.6生成模板界面 58第六章課題總結(jié) 60致謝 62參考文獻(xiàn) 63附錄 65PAGE80 PAGE81第一章概述1.1課題背景與意義現(xiàn)在是信息社會(huì),各種信息都需要處理并直觀展現(xiàn),如股票,物價(jià)等信息都需要通過(guò)數(shù)據(jù)報(bào)表來(lái)展現(xiàn)、分析,因此對(duì)高質(zhì)量報(bào)表軟件系統(tǒng)的需求非常強(qiáng)烈。報(bào)表設(shè)計(jì)工具是報(bào)表系統(tǒng)的重要組成部分,使用報(bào)表設(shè)計(jì)工具,可對(duì)企業(yè)以及其他用戶需要的各種報(bào)表進(jìn)行設(shè)計(jì),并在報(bào)表引擎上運(yùn)行。報(bào)表設(shè)計(jì)工具的功能包括數(shù)據(jù)源關(guān)聯(lián)與訪問、報(bào)表繪制、布局繪制、屬性編輯、腳本編輯、圖表編輯、表達(dá)式編輯、報(bào)表數(shù)據(jù)映射、報(bào)表預(yù)覽調(diào)試等??赏ㄟ^(guò)XML轉(zhuǎn)換技術(shù)將報(bào)表轉(zhuǎn)換換為PDF、Excel等格式輸出。隨著B/S應(yīng)用逐步取代C/S,市場(chǎng)上對(duì)Web環(huán)境下運(yùn)行報(bào)表的要求日益強(qiáng)烈,C/S時(shí)期的報(bào)表工具紛紛進(jìn)行了若干改進(jìn)與加強(qiáng),支持B/S結(jié)構(gòu)。這些工具大都是對(duì)開源軟件進(jìn)行包裝改造,基本上有兩種流派:一類來(lái)自于FastReport這種基于Delphi的軟件,通過(guò)控件方式實(shí)現(xiàn)Web報(bào)表,進(jìn)而將報(bào)表計(jì)算移至服務(wù)器上進(jìn)行,再改進(jìn)為支持Linux;另一類來(lái)自于Jasper的基于Java的開源軟件。這些工具的整體思路還是沿襲了C/S時(shí)的方式,仍然是傳統(tǒng)的分組報(bào)表的模式,仍然無(wú)法解決表樣和大作量的代碼編寫問題,而且使用復(fù)雜,不能很好的發(fā)揮其效率,不能利用已有的軟件功能,同時(shí)他們都是利用SWING/AWT來(lái)開發(fā)的,界面難看。

因此,開發(fā)一個(gè)具有B/S結(jié)構(gòu)、能適應(yīng)中國(guó)國(guó)情、開源的、使用方便、界面美觀的報(bào)表設(shè)計(jì)器是一個(gè)很多用戶直期待的。但是,目前流行的報(bào)表軟件產(chǎn)品中,比較適合中國(guó)情況的產(chǎn)品還是不多。因此,進(jìn)行本課題研究,開發(fā)報(bào)表設(shè)計(jì)器軟件,對(duì)于開發(fā)適合中國(guó)特點(diǎn)的實(shí)用報(bào)表系統(tǒng),促進(jìn)企業(yè)與社會(huì)信息化,具有很好的實(shí)際意義。1.2報(bào)表系統(tǒng)發(fā)展概況信息化的初期階段,計(jì)算機(jī)作為一種新的生產(chǎn)工具,其主要功能是文字輸出,如文件打印、表格輸出等,相比較手工方式而言,工作效率大大提高。這個(gè)時(shí)期,用于報(bào)表生成的軟件主要是WPS表格、CCED、Excel等文字處理工具,這些工具僅僅是將手工繪制報(bào)表的方式改為電子處理方式,未涉及到報(bào)表數(shù)據(jù)的集中、共享等處理。更確切地說(shuō),這個(gè)時(shí)期還沒有真正意義上的報(bào)表工具。

隨著信息化程度的不斷提高,C/S應(yīng)用方式逐漸成熟,出現(xiàn)了很多報(bào)表工具軟件,最著名的當(dāng)屬水晶報(bào)表和PB的DataWindow。水晶報(bào)表在上世紀(jì)一直被微軟OEM,成為VB的內(nèi)置報(bào)表工具,在微軟的強(qiáng)大支持下,VB龐大的用戶群為水晶報(bào)表培養(yǎng)了眾多應(yīng)用人員并積累了大量成功案例,從而產(chǎn)生了世界第一(用戶量)的報(bào)表工具。DataWindow是PB中獲取專利技術(shù)的控件,它對(duì)數(shù)據(jù)的處理方法相當(dāng)簡(jiǎn)潔,能處理各種顯示格式,快速的報(bào)表制作能力深受PB開發(fā)者的喜愛。

這些軟件的基本特征是單數(shù)據(jù)源、條帶式(BAND)分組統(tǒng)計(jì)模型,通過(guò)控件拖拽方式繪制報(bào)表,在不編碼的情況下能完成簡(jiǎn)單地行式(分組)報(bào)表和單片交叉報(bào)表,數(shù)據(jù)集中在數(shù)據(jù)庫(kù)中,可以共享。

但這一時(shí)期的用戶需求已經(jīng)與前一階段的需求大為不同。用戶希望放在數(shù)據(jù)庫(kù)中的數(shù)據(jù)能以自己熟悉的方式展現(xiàn)(復(fù)雜的表樣、統(tǒng)計(jì)運(yùn)算等),而這些報(bào)表軟件的數(shù)據(jù)模型源于國(guó)外的報(bào)表習(xí)慣,解決復(fù)雜表樣的方法并不好,復(fù)雜的統(tǒng)計(jì)運(yùn)算也要求開發(fā)人員編寫大量的程序代碼,導(dǎo)致報(bào)表開發(fā)時(shí)間太長(zhǎng),后期的維護(hù)工作量也很大。隨著B/S應(yīng)用逐步取代C/S,市場(chǎng)上對(duì)Web報(bào)表的要求越來(lái)越強(qiáng)烈,C/S時(shí)期的報(bào)表工具紛紛進(jìn)行了若干改進(jìn)與加強(qiáng),普遍支持B/S結(jié)構(gòu),新的報(bào)表軟件也如雨后春筍一樣不斷出現(xiàn)。在報(bào)表工具的發(fā)展過(guò)程中,還有一類特殊的表格式產(chǎn)品,最著名有ormula1和華表。這種類Excel的工具,展現(xiàn)能力非常強(qiáng),但是因?yàn)闆]有數(shù)據(jù)模型,導(dǎo)致其數(shù)據(jù)處理能力幾乎為零,程序員需要按格編寫代碼往里填數(shù)。相比較分組式報(bào)表工具,類Excel工具能徹底解決復(fù)雜報(bào)表的樣式問題,所以在實(shí)際應(yīng)用中它一直是與分組報(bào)表互補(bǔ)的一類產(chǎn)品。SWT/JFACE是Eclipse推出優(yōu)秀的JAVA圖形API。RCP,也就是富客戶端,是在Eclipse3.0之后分離出來(lái)的一個(gè)平臺(tái)。RCP技術(shù)其實(shí)就是插件開發(fā),可以在一個(gè)很小的模板上加入各種插件,擴(kuò)展性能。現(xiàn)在RCP已經(jīng)成為Eclipse開源項(xiàng)目的一個(gè)亮點(diǎn),在國(guó)際上廣泛的使用大量PCR來(lái)開發(fā)桌面應(yīng)用程序。在RCP平臺(tái)上,可以使用Eclipse的插件機(jī)制來(lái)快速開發(fā)獨(dú)立應(yīng)用的桌面應(yīng)用,從而輕松擁有Eclipse的界面結(jié)構(gòu)和界面元素,節(jié)省了很多開發(fā)精力。運(yùn)用SWT/Jface和RCP技術(shù)來(lái)開發(fā)報(bào)表,是當(dāng)前報(bào)表開發(fā)的主流方向。一方面,SWT/Jface可以提供優(yōu)秀的圖形界面,克服JAVA桌面應(yīng)用界面難看的缺陷;另一方面RCP技術(shù)可以提高開發(fā)效率。聯(lián)合運(yùn)用SWT/Jface和RCP技術(shù),可以開發(fā)出優(yōu)秀的報(bào)表產(chǎn)品。第二章開發(fā)技術(shù)及環(huán)境2.1軟件環(huán)境本系統(tǒng)的開發(fā)環(huán)境:操作系統(tǒng):Windowserver2003標(biāo)準(zhǔn)版應(yīng)用服務(wù)器:Tomcat5.5開發(fā)平臺(tái):eclipse3.3;jdk1.52.2主要開發(fā)技術(shù)SWT/JfaceSWT(StandardWidgetToolkit)是標(biāo)準(zhǔn)控件工具集。Jface意為JAVAface。由于SUN的AWT/SWING技術(shù)在與本地界面融合方面存在缺陷,因此IBM開發(fā)了SWT,使得界面風(fēng)格和本地保持一致。而Jface是SWTa的擴(kuò)展包,采用MVC的設(shè)計(jì)模式,使用更加方面。RCPRCP(RichClientPlatform)意為富客戶平臺(tái)。在RCP平臺(tái)上,可使用Eclipse的插件機(jī)制來(lái)快速開發(fā)獨(dú)立應(yīng)用的桌面應(yīng)用,從而輕松擁有Eclipse的界面結(jié)構(gòu)和界面元素,節(jié)省了很多開發(fā)精力。Dom4jDom4j(DocumentObjectModelforJAVA)是一個(gè)易用的、開源的庫(kù),用于XML,XPath和XSLT。它應(yīng)用于Java平臺(tái),采用了Java集合框架并完全支持DOM,SAX和JAXP。Dom4j使用起來(lái)非常簡(jiǎn)單,效率高。只要了解基本的XML-DOM模型就能使用。POIPOI(PointofInterest)意為為興趣點(diǎn),是JAVA與MSOffice交互時(shí)用到的第三方JAR,也是開源的,屬于Apache的一個(gè)項(xiàng)目,用法簡(jiǎn)單。它主要用來(lái)讀寫OLE2復(fù)合文檔結(jié)構(gòu),本系統(tǒng)主要用它來(lái)操作EXCEL。ITextiText是著名的開放源碼的站點(diǎn)sourceforge一個(gè)項(xiàng)目,是用于生成PDF文檔的一個(gè)java類庫(kù)。通過(guò)iText不僅可以生成PDF或rtf的文檔,而且可以將XML、Html文件轉(zhuǎn)化為PDF文件。用法很簡(jiǎn)單,效率很高。Lombozlomboz是用來(lái)開發(fā)j2ee應(yīng)用、免費(fèi)eclipse插件,用它可以大大加快web開發(fā)、部署等工作。第三章系統(tǒng)設(shè)計(jì)3.1系統(tǒng)體系結(jié)構(gòu)本系統(tǒng)采用三層B/S架構(gòu),分別為表示層、設(shè)計(jì)層和數(shù)據(jù)層,如圖3-1所示。表示層(Presentation-Tier)是報(bào)表顯示層。本報(bào)表系統(tǒng)的表示層有三種類型:Web類型,Excel類型,Pdf類型。(2)設(shè)計(jì)層(Designer-Tier)是本報(bào)表系統(tǒng)的重中之重。設(shè)計(jì)層設(shè)計(jì)的好壞直接影響到報(bào)表的使用。其主要任務(wù)是建立報(bào)表、修改報(bào)表、發(fā)布報(bào)表、生成模板等。這涉及到報(bào)表的數(shù)據(jù)來(lái)源,報(bào)表的格式,報(bào)表輸出,是連接表示層和數(shù)據(jù)層的橋梁。(3)數(shù)據(jù)層(Data-Tier)主要是和用戶有關(guān)。本報(bào)表系統(tǒng)可以與幾種常用的數(shù)據(jù)庫(kù)系統(tǒng)交互。報(bào)表中可以輸入的數(shù)據(jù)很多,如圖表、序列號(hào)、常量等。數(shù)據(jù)層可以存儲(chǔ)并管理這些數(shù)據(jù)。圖3-1系統(tǒng)體系結(jié)構(gòu)圖3.2軟件模塊結(jié)構(gòu)本系統(tǒng)的軟件模塊結(jié)構(gòu),如圖3-2所示。圖3-2系統(tǒng)軟件模塊結(jié)構(gòu)圖圖3-2中各模塊的基本功能如下:新建報(bào)表:設(shè)置報(bào)表的名字、每頁(yè)顯示數(shù)目、選用報(bào)表模板;把這些數(shù)據(jù)存到Preferences中,供保存報(bào)表使用。新建數(shù)據(jù)源:設(shè)置數(shù)據(jù)源名稱,用它來(lái)標(biāo)識(shí)數(shù)據(jù)連接;選擇數(shù)據(jù)庫(kù)類型,并設(shè)置各種連接參數(shù);進(jìn)行數(shù)據(jù)源說(shuō)明;進(jìn)行連接測(cè)試;連接成功后把數(shù)據(jù)源名稱和各種連接參數(shù)保存到dataSource.xml文件中,供以后使用;而數(shù)據(jù)源說(shuō)明就生成一個(gè)文本文件保存。編輯單元格:設(shè)置單元格的數(shù)據(jù),如數(shù)據(jù)源列、函數(shù)、系列號(hào)、圖像;設(shè)置顏色,字體;設(shè)置所對(duì)應(yīng)的行列是否擴(kuò)展,所對(duì)應(yīng)的行列是否排序。這些都要用一定的格式保存起來(lái),供報(bào)表顯示時(shí)使用。保存報(bào)表:設(shè)置單元格屬性后,保存設(shè)置內(nèi)容。先從Preferences讀取報(bào)表相關(guān)數(shù)據(jù),然后生成報(bào)表的xml;遍歷表格,把表格各種信息填到xml中。編輯報(bào)表:保存表格后,如覺得不滿意,可以打開報(bào)表修改。讀取xml,把相關(guān)信息填到相應(yīng)的單元格。也可以設(shè)置報(bào)表的每頁(yè)的行數(shù)、報(bào)表發(fā)布者、發(fā)布時(shí)間、報(bào)表說(shuō)明。生成電子表格:電子表格可用來(lái)直接發(fā)布,也可用來(lái)編輯。先讀取報(bào)表xml文件,得到各個(gè)單元格的數(shù)據(jù)源,根據(jù)數(shù)據(jù)源不同,得到不同的數(shù)據(jù),并填到相應(yīng)的電子表格內(nèi)??梢栽O(shè)置電子表格的屬性。發(fā)布報(bào)表:先設(shè)置發(fā)布目錄,然后把項(xiàng)目文件夾下Files目錄下的名和Preferences中保存相同的,后綴名為xml、xls、css、pdf的文件都復(fù)制到發(fā)布目錄下。如發(fā)布目錄已有相同文件,就覆蓋。編輯CSS:CSS決定網(wǎng)頁(yè)頁(yè)面顯示格式,對(duì)報(bào)表非常重要。本系統(tǒng)提供一個(gè)模板,旁邊還有介紹各種標(biāo)記的代表的內(nèi)容的提示,這樣用戶就可以自己修改它。修改完后點(diǎn)“確定”,生成報(bào)表名+“.css”的樣式文件。生成模板:CSS不是很難,但要做一個(gè)好看的格式卻很難,所心有必要把前面生成的CSS文件保存起來(lái),提供下次使用。首先設(shè)置模板名字,然后設(shè)置說(shuō)明,點(diǎn)“確定”后,系統(tǒng)會(huì)把當(dāng)前報(bào)表的CSS文件復(fù)制到模板xml文件,并生成說(shuō)明的txt文件。配置服務(wù)器:配置發(fā)布目錄、端口、最大線程數(shù),以方便使用。3.3數(shù)據(jù)源與系統(tǒng)文件結(jié)構(gòu)3.3.1系統(tǒng)數(shù)據(jù)源報(bào)表就是數(shù)據(jù)的顯示,所以數(shù)據(jù)源很重要。本系統(tǒng)的數(shù)據(jù)源方案如下:提供建立數(shù)據(jù)源及管理數(shù)據(jù)源的功能。針對(duì)不同類型的數(shù)據(jù)庫(kù)數(shù)據(jù),建立相應(yīng)的數(shù)據(jù)源。建立了數(shù)據(jù)源后,就用一個(gè)XML文件保存數(shù)據(jù)源信息,以后可直接從XML文件讀取或修改連接信息。提供對(duì)其它類型數(shù)據(jù)源的支持。主要支持EXCEL文件、函數(shù)、系列號(hào)、公式等數(shù)據(jù)源。EXCEL文件可以直接解析為WEB格式,而函數(shù),系列號(hào),公式,圖像等可以直接插入。3.3.2系統(tǒng)文件結(jié)構(gòu)本系統(tǒng)作為一個(gè)桌面應(yīng)用系統(tǒng),涉及到許多文件系統(tǒng),不管用戶還是開發(fā)者,都有可能容易迷失在文件堆中,所以必須科學(xué)管理。為了解決此問題,本系統(tǒng)設(shè)計(jì)了系統(tǒng)主目錄文件結(jié)構(gòu),以下是系統(tǒng)主目錄的的文件截圖:圖3-4系統(tǒng)主目錄文件結(jié)構(gòu)圖圖3-4中各文件的功能如下:.metadata文件夾:系統(tǒng)自動(dòng)生成,保存有日志文件。.setting文件夾:系統(tǒng)自動(dòng)生成,用于保存項(xiàng)目的各個(gè)參數(shù)。Bin文件夾:存放已經(jīng)編譯過(guò)的JAVA的.class文件。DataSource文件夾:存放數(shù)據(jù)源的dataSource.xml文件,其中還有各種.txt文件,用來(lái)說(shuō)明各個(gè)數(shù)據(jù)源。該文件夾結(jié)構(gòu)如圖3-5所示:圖3-5DataSource文件夾示意圖Files文件夾:用來(lái)存放所生成的報(bào)表。其中有存放報(bào)表信息的xml文件,也有生成為電子表格的.xls文件、pdf文件。當(dāng)然也存放了報(bào)表說(shuō)明的.txt文件,其結(jié)構(gòu)如圖3-6所示:圖3-6Files文件夾示意圖圖3-6Files文件夾結(jié)構(gòu)示意圖icons文件夾:用來(lái)存放圖象,如按鈕圖標(biāo)。intro文件夾:系統(tǒng)自動(dòng)生成。lib文件夾:用來(lái)存放第三方JAR包。META-INF文件夾:系統(tǒng)自動(dòng)生成,里面有MENIFEST.MF,在這個(gè)文件里有描述插件各種信息基本信息。src文件夾:是源文件,其結(jié)構(gòu)如下圖所示:圖3-7src文件夾示意圖從圖中可知,src文件夾包括兩個(gè)包,一個(gè)是xautreportdesign包,里面有Activator.java文件,這是RCP的激活類。另一個(gè)是com包。其實(shí)這個(gè)包里有三個(gè)子包:com.Xautreportdesign.action,主要用來(lái)存放菜單,工具欄動(dòng)作類的;com.Xautreportdesign.util,主要用來(lái)存放一些工具類的,這些工具類對(duì)全局都有用;com.Xautreportdesign.win,主要是界面方面的類,有一些是自動(dòng)生成后我修改的。com.Xautreportdesign.action包中的一部分類如圖3-8所示:圖3-8com.Xautreportdesign.action包中文件示意圖com.Xautreportdesign.util包中的類如圖3-9所示:圖3-9com.Xautreportdesign.util包中文件示意圖com.Xautreportdesign.win包中類類如圖3-10所示:圖3-10com.Xautreportdesign.win包中文件示意圖Template文件夾:是保存模板的文件夾,里面有模板文件.css文件,也有模板說(shuō)明.txt文件,如圖3-11所示:圖3-11Template文件夾示意圖.classpath、.project、perties、javaCompiler...args、plugin.xml、plugin_customization.ini都是系統(tǒng)自動(dòng)生成的。build.xml:是用ant生成的,為系統(tǒng)打包用。Rduct:是要生成的新產(chǎn)品配置文件。splash.bmp:系統(tǒng)啟動(dòng)時(shí)產(chǎn)閃動(dòng)畫面使用。3.3.3報(bào)表顯示部分文件對(duì)于報(bào)表WEB顯示部分,有如下重要文件或文件夾:dataSource文件夾:存放數(shù)據(jù)源文件dataSourece.xml。photo文件夾:存放需要的圖片文件。.css文件:是報(bào)表的css文件。report.jsp:是解析保存報(bào)表信息的.xml的文件。exceltoweb.jsp:是解析EXCEL并生成WEB的文件。第四章系統(tǒng)實(shí)現(xiàn)4.1主要實(shí)現(xiàn)算法4.1.1新建報(bào)表流程圖圖4-1新建報(bào)表算法流程圖該算法首先判斷是否已有同名的報(bào)表,然后判斷行數(shù)是否為數(shù)字,最后存入Preferences中。4.1.2新建數(shù)據(jù)源流程圖圖4-2新建數(shù)據(jù)源算法流程圖該算法先選擇合適自己的數(shù)據(jù)庫(kù),然后輸入信息,最后連接,看是否成功,若成功就把信息保存起來(lái)。4.1.3編輯單元格流程圖圖4-3新建報(bào)表算法流程圖該算法首先要得到當(dāng)前鼠標(biāo)的位置,然后轉(zhuǎn)化為表格的行列,最后選擇數(shù)據(jù)源,并設(shè)置單元格屬性。4.1.4保存報(bào)表流程圖圖4-4保存報(bào)表算法流程圖該算法首先從Preferences中讀取報(bào)表相關(guān)信息,生成報(bào)表名的xml文件。然后遍歷表格,讀取各非空單元格的值及屬性,填入寫入小xml文件中,最后看是否用到模板,如用到,就生成報(bào)表名的css文件。生成xml的代碼如下所示:<XautReportFileName="zainan"tempname="Template"rownum="8"ownerName="楊濟(jì)忠"time="2008年6月3日"intro="true"><Columns><ColumnDataSource="D:zainanDS.ID"Span="縱擴(kuò)展"Arrange="不排序"Color="RGB{255,255,255}"Font="Tahoma.8.0">A1</Column>在XautReportFile中,“Name”代表報(bào)表的名字,“tempname”代表報(bào)表用到的模板,“rownum”代表WEB頁(yè)每頁(yè)顯示的行數(shù),“ownerName”代表作者,time代表發(fā)布時(shí)間,intro代表是否有說(shuō)明內(nèi)容。而Columm代表一個(gè)單元格,“DataSource”代表數(shù)據(jù)源,里面不同的部分又代表不同的意思:如前面為“D:”,那代表數(shù)據(jù)庫(kù),中間代表前面建的數(shù)據(jù)源的名稱,最后代碼數(shù)據(jù)源的列。如前面是“I:”,那代表常量,后面部分就是常量的值。、如前面是“S:”,那代表系列號(hào),后面代表系列號(hào)的一部分。如前面是“F:”,那代表的是函數(shù),后面是函數(shù)?!癝pan”,代表擴(kuò)展情況。擴(kuò)展就是其它單元格的值是否依賴這個(gè)單元格的值;“Arrange”代表是否排序;“Color”代表是顏色,;“Font”代表字體。而這個(gè)單元格的ID是A1。4.1.5生成電子表格流程圖

圖4-5生成電子表格算法流程圖該算法首先從Preferences中得到當(dāng)前報(bào)表名,然后讀取報(bào)表XML文件,得到數(shù)據(jù)源名稱。讀取數(shù)據(jù)源XML,遍歷得到數(shù)據(jù)源的各種參數(shù)。用這些參數(shù)連接數(shù)據(jù)庫(kù)。用POI創(chuàng)建EXCEL文件。把數(shù)據(jù)庫(kù)中數(shù)據(jù)寫入EXCEL文件。4.1.6發(fā)布報(bào)表流程圖圖4-6發(fā)布報(bào)表算法流程圖該算法首先從Preferences中查看發(fā)布目錄,如有,就復(fù)制報(bào)表XML到發(fā)布目錄,如沒有,就設(shè)置。然后就開始判斷是否有相關(guān)文件,如有,就一同復(fù)制,因?yàn)椴粡?fù)制,就沒有用。4.1.7編輯CSS流程圖圖4-7編輯CSS算法流程圖該算法首先從CSS模板中讀出模板內(nèi)容,并顯示出來(lái),提供用戶修改。修改完成后點(diǎn)確定,從Preferences得當(dāng)前報(bào)表,然后生成報(bào)表的CSS文件,如已有相同的就覆蓋。最后把修改后的CSS寫入報(bào)表文件。4.1.8生成模板流程圖圖4-8生成模板算法流程圖該算法首先設(shè)置要生成模板的模板名及說(shuō)明。然后生成模板文件,當(dāng)然是CSS類型。如模板說(shuō)明不為空,也生成文件文件類型的說(shuō)明書。然后從Preferences中得到當(dāng)前報(bào)表,由此得到當(dāng)前報(bào)表的CSS文件,最后把這CSS文件的內(nèi)容寫入模板文件里。4.1.9配置服務(wù)器流程圖圖4-9配置服務(wù)器算法流程圖該算法首先讀取服務(wù)器配置文件并顯示各個(gè)參數(shù),這可以修改。點(diǎn)確定后,就把修改后值寫入配置文件,并更新相關(guān)視圖。4.2系統(tǒng)編碼實(shí)現(xiàn)4.2.1系統(tǒng)的主界面實(shí)現(xiàn)本系統(tǒng)采用EclipseRCP技術(shù),也就是開發(fā)可以獨(dú)立運(yùn)行的Eclipse的插件。運(yùn)用RCP技術(shù),可以實(shí)現(xiàn)與Eclipse一樣友好的界面,可以方便地組裝成一個(gè)很強(qiáng)大的系統(tǒng),因?yàn)檫@是采用插件機(jī)制。本系統(tǒng)的主界面如圖4-1所示:圖4-1報(bào)表設(shè)計(jì)系統(tǒng)主界面圖由圖4-1可以看到,本系統(tǒng)和Eclipse界面有很大的相似性。本系統(tǒng)主要用到了包c(diǎn)om.xautreportdesign.win。其中各個(gè)類的功能及重要代碼說(shuō)明如下:Application類:是RCP程序的入口類,RCP程序啟動(dòng)后第一個(gè)執(zhí)行就是它,它負(fù)責(zé)程序的載入與退出。這個(gè)類是建立項(xiàng)目后自動(dòng)生成的,平常情況不需要修改。ApplicationWorkbenchAdvisor類:是配置工作臺(tái)的類,工作臺(tái)的初始化就在這完成。這個(gè)類是建立項(xiàng)目后自動(dòng)生成的,可以修改成自己需要的。這個(gè)類的部分代碼如下:ApplicationWorkbenchWindowAdvisor類:用來(lái)設(shè)置窗口。一個(gè)工作臺(tái)可以有多個(gè)窗口,所以可以多個(gè)該類的對(duì)象。這個(gè)類是建立項(xiàng)目后自動(dòng)生成的,可以修改成自己需要的。下面代碼說(shuō)明了窗口大小為(700,550),有工具欄,窗口標(biāo)題,顯示狀態(tài)欄,生成系統(tǒng)托盤等。以下是該類的部分實(shí)現(xiàn)代碼:publicvoidpreWindowOpen(){ /**設(shè)置窗口初始化的各種屬性*/ IWorkbenchWindowConfigurerconfigurer=getWindowConfigurer(); configurer.setInitialSize(newPoint(700,550)); configurer.setShowCoolBar(true); configurer.setShowStatusLine(false); configurer.setTitle("報(bào)表生成系統(tǒng)"); configurer.setShowPerspectiveBar(true); configurer.setShowStatusLine(true); finalIWorkbenchWindowwindow=getWindowConfigurer().getWindow(); /**創(chuàng)建系統(tǒng)托盤*/ trayItem=initTrayItem(window); /**如果支持系統(tǒng)托盤,則創(chuàng)建托盤的菜單*/ if(trayItem!=null){ createPopupMenu(window); } }Perspective類:是透視圖類。透視圖是各個(gè)視圖,編輯面組成的一個(gè)專用的程序界面。本類是項(xiàng)目默認(rèn)生成,當(dāng)然也可以寫自己的視圖,只要實(shí)現(xiàn)IperspectiveFactory接口。下面就是本透視圖的布局部分代碼,效果如圖4-1所示。publicvoidcreateInitialLayout(IPageLayoutlayout){ StringeditorArea=layout.getEditorArea(); layout.setEditorAreaVisible(true); layout.setFixed(false); //layout.addView(View.ID,IPageLayout.LEFT,0.25f,editorArea); IFolderLayoutleft=layout.createFolder("left",IPageLayout.LEFT, 0.25f,editorArea); left.addPlaceholder(DatasourceView.ID); left.addPlaceholder(ServerView.ID); layout.getViewLayout(ServerView.ID).setCloseable(false); layout.getViewLayout(ServerView.ID).setMoveable(false); layout.addPlaceholder(editAreaView.ID,IPageLayout.TOP,0.50f, editorArea); layout.addPlaceholder(AttributeView.ID,IPageLayout.BOTTOM,0.25f, editorArea); layout.getViewLayout(AttributeView.ID).setCloseable(false); layout.getViewLayout(AttributeView.ID).setMoveable(false); }ApplicationActionBarAdvisor類:負(fù)責(zé)創(chuàng)建和配置工作臺(tái)窗口上主菜單,工具欄,狀態(tài)欄等,是報(bào)表各種功能模塊相關(guān)入口。下面的代碼是用來(lái)建立系統(tǒng)托盤項(xiàng)。其中newSeparator()是畫一條分隔線,在菜單工具欄中也用到。publicvoidfillTrayItem(MenuManagertrayMenu){ trayMenu.add(deployAction); trayMenu.add(newSeparator()); trayMenu.add(exampleAction); trayMenu.add(aboutAction);editAreaView類:是編輯視圖類。視圖相當(dāng)于一個(gè)小窗口,顯示某一方面的內(nèi)容,可以在一個(gè)頁(yè)面上放置幾個(gè)視圖。視圖可通過(guò)兩種方式創(chuàng)建:一.通過(guò)擴(kuò)展點(diǎn):修改plugin.xml文件,設(shè)置視圖擴(kuò)展點(diǎn),在最后一行的</plugin>前加入,下面的代碼說(shuō)明了擴(kuò)展點(diǎn)是org.eclipse.ui.views,視圖名字是“編輯區(qū)”,對(duì)應(yīng)的JAVA文件是com.xautreportdesign.win.editAreaView,ID是視圖的標(biāo)識(shí),為XautReportDesign.EditAreaView。對(duì)于其它視圖,都可以這樣創(chuàng)建:<extensionpoint="org.eclipse.ui.views"><viewname="編輯區(qū)"class="com.xautreportdesign.win.editAreaView"id="XautReportDesign.EditAreaView"></view></extension>二.通過(guò)繼承抽象類ViewPart類,要改寫類中createPartControl,setFocus方法。本視圖實(shí)現(xiàn)部分的代碼如下所示:publicvoidcreatePartControl(Compositeparent){ createToolbar(); if(!isedit){ setPartName("編輯"+reportName); }else setPartName("(未保存)編輯"+reportName); createTable(parent,colnum,rownum); }上面的代碼是實(shí)現(xiàn)視圖內(nèi)容,其中最重要的是createTable()方法。這個(gè)方法是在視圖中創(chuàng)建類似EXCEL中的表格。下面的代碼創(chuàng)建一個(gè)表格,并設(shè)置表格的樣式,部分代碼如下:Compositec1=newComposite(parent,SWT.NONE); c1.setLayout(newFillLayout()); table=newTable(c1,SWT.SINGLE|SWT.HIDE_SELECTION |SWT.FULL_SELECTION); table.setHeaderVisible(true); table.setLinesVisible(true); table.setRedraw(true);對(duì)于表格的列號(hào),下面的代碼創(chuàng)建列名從A開始的20個(gè)列,其中得把數(shù)字轉(zhuǎn)化為字符型,其實(shí)現(xiàn)代碼如下:for(inti=0;i<20;i++){ TableColumncolumn=newTableColumn(table,SWT.CENTER); column.setText(""+String.valueOf((char)(65+i))+""); column.pack(); } 而對(duì)于行號(hào),下面的方法把按鈕附加到每一行的第一列,在按鈕上寫數(shù)字。這樣做的原因是使表格可編輯。實(shí)現(xiàn)方法如下: Buttonb[]=newButton[30]; for(inti=0;i<30;i++){ finalTableItemitem=newTableItem(table,SWT.NONE); item.setText(i+1,""); editor[i]=newTableEditor(table); b[i]=newButton(table,SWT.PUSH); b[i].setText(""+(i+1)+""); editor[i].grabHorizontal=true; editor[i].minimumHeight=b[i].getSize().y; editor[i].minimumWidth=b[i].getSize().x; editor[i].setEditor(b[i],item,0); }編輯是在屬性視圖完成的,所以需完成數(shù)據(jù)綁定。下面代碼的作用是數(shù)據(jù)綁定,它獲取鼠標(biāo)所在單元格:table.addMouseListener(newMouseAdapter(){ publicvoidmouseDown(MouseEventevent){ Controlold=editor1.getEditor(); if(old!=null) old.dispose(); Pointpt=newPoint(event.x,event.y); finalTableItemitem=table.getItem(pt); if(item!=null){ intcolumn=-1; for(inti=0;i<=20;i++){ Rectanglerect=item.getBounds(i); if(rect.contains(pt)){ column=i; break; } }要把表格內(nèi)容填到屬性視圖中相應(yīng)的組件上,實(shí)現(xiàn)的方法是首先得到屬性視圖,其中通過(guò)getter()方法得到視圖組件,這樣就可以修改組件的值,同時(shí)得到表格單元格的值,用字符串分析技術(shù)得到不同的值,并填充到屬性視圖table中。實(shí)現(xiàn)代碼如下:finalintcol=column; //數(shù)據(jù)綁定 IViewPartvp=getViewSite().getPage().findView( AttributeView.ID); AttributeViewav=(AttributeView)vp; LabeltitleLabel=av.getLabel1(); StringcolId=String .valueOf(table.getSelectionIndex()+1); titleLabel.setText("單元格:" +String.valueOf((char)(64+column))+colId); Combocombo=av.getCombo(); Combocombo11=av.getCombo11(); Combocombo1=av.getCombo1(); Combocombo2=av.getCombo2(); StringcolumnValue=item.getText(column); inti=columnValue.indexOf("@",1); if(i==-1){ combo.select(0); combo11.select(0); combo1.select(0); combo2.select(0); }else{ Stringdatasource=columnValue.substring(0,i); if(datasource.startsWith("F:")){ combo.select(2); combo11.setText(datasource.substring(2)); }elseif(datasource.startsWith("S:")){ combo.select(1); combo11.setText(datasource.substring(2)); }elseif(datasource.startsWith("D:")){ intn=datasource.indexOf("."); combo.setText(datasource.substring(2,n)); combo11.setText(datasource.substring(n+1)); }elseif(datasource.startsWith("I:")){ combo.select(0); combo11.setText(datasource.substring(2)); }else{ combo.select(0); combo11.setText(datasource); }AttributeView類:是屬性視圖類,也就是用來(lái)修改單元格的屬性。本視圖的重點(diǎn)工作是編輯單元格屬性,所以工作重點(diǎn)是和編輯視圖交互,部分代碼如下:publicvoidfillInTable(finalCompositeparent) throwsNumberFormatException{ IViewPartvp=getViewSite().getPage().findView(editAreaView.ID); editAreaVieweav=(editAreaView)vp; Tabletable=eav.getTable(); inti=label1.getText().indexOf(":"); StringtableLocal=label1.getText().substring(i+1); Stringcolid=tableLocal.substring(0,1); Stringrowid=tableLocal.substring(1); char[]char1=colid.toCharArray(); intk=char1[0]-64; TableItemitem=table.getItem(Integer.parseInt(rowid)-1); StringvalueString="";if(combo.getSelectionIndex()==0){ valueString="I:"+combo11.getText()+"@"+combo1.getText() +"@"+combo2.getText(); }elseif(combo.getSelectionIndex()==1){ valueString="S:"+combo11.getText()+"@"+combo1.getText() +"@"+combo2.getText(); }elseif(combo.getSelectionIndex()==2){ valueString="F:"+combo11.getText()+"@"+combo1.getText() +"@"+combo2.getText(); }else{ valueString="D:"+combo.getText()+"."+combo11.getText() +"@"+combo1.getText()+"@"+combo2.getText(); }item.setText(k,valueString); MessageDialog.openInformation(parent.getShell(),"修改成功","修改成功!"); }上述代碼中,首先得到編輯視圖,然后得到視圖表格,最后定位到具體單元格。然后把各個(gè)控件的值按一定的格式寫入單元格。然后提示修改成功。DatasourceView類:顯示已有的數(shù)據(jù)源及數(shù)據(jù)源的列。主要是讀取Datasource文件夾下dataSourece.xml文件中的內(nèi)容,并把它們用樹形表示出來(lái)。ServerView類:是服務(wù)器視圖,顯示已發(fā)布到服務(wù)器上的報(bào)表文件,包括xml,excel,pdf文件。這是用TreeViewer來(lái)實(shí)現(xiàn)的,這個(gè)類采用MVC設(shè)計(jì)模式,必須實(shí)現(xiàn)setContentProvider,setLabelProvider方法。實(shí)現(xiàn)代碼如下:tree.setContentProvider(newITreeContentProvider(){ privateStringpath; publicObject[]getChildren(Objectelement){ return((File)element).listFiles(); } publicObject[]getElements(Objectelement){ Preferencespreferences=newConfigurationScope() .getNode("com.XautReportDduct"); try{//得到報(bào)表文件夾目錄 path=FileLocator.toFileURL( Platform.getBundle("XautReportDesign") .getEntry("")).getPath().toString() +"Files/"; }catch(IOExceptione){ e.printStackTrace(); }//如果發(fā)布目錄不存在,就用報(bào)表文件夾目錄 StringdeployDirectry=preferences.get("deployDirectry",path .substring(1)); FilecFile=newFile(deployDirectry); File[]roots=cFile.listFiles(); List<File>rootFolders=newArrayList<File>(); for(inti=0;i<roots.length;i++){ if(roots[i].isFile() &&(roots[i].getAbsolutePath().endsWith("xml") ||roots[i].getAbsolutePath().endsWith( "pdf")||roots[i] .getAbsolutePath().endsWith("xls"))) rootFolders.add(roots[i]); } returnrootFolders.toArray(); } publicbooleanhasChildren(Objectelement){ Object[]obj=getChildren(element); returnobj==null?false:obj.length>0; } publicObjectgetParent(Objectelement){ return((File)element).getParentFile(); } publicvoiddispose(){ } publicvoidinputChanged(Viewerviewer,ObjectoldInput, ObjectnewInput){ } });上面代碼用到了Preferences,它是一種持久化API,其目的是存儲(chǔ)少量數(shù)據(jù)提供一個(gè)高效的存儲(chǔ)設(shè)備。Preferences采用樹形結(jié)構(gòu),用Key/Value格式。本系統(tǒng)中用它來(lái)存儲(chǔ)正在編輯報(bào)表名稱,報(bào)表發(fā)布目錄等。StringdeployDirectry=preferences.get("deployDirectry",path .substring(1));上面的代碼說(shuō)明,如果沒有前面的值,deployDirectry就用等于后面的值。得到文件目錄后,就用遍歷找出后綴名為xml、xls、pdf的文件,并顯示。4.2.2新建數(shù)據(jù)源報(bào)表要與各種數(shù)據(jù)打交道。新建數(shù)據(jù)源的對(duì)話框如圖4-3所示。新建數(shù)據(jù)源用到的菜單類為newDataSourceAction,newDataSourceDialog類。NewDataSourceAction繼承Action類,并實(shí)現(xiàn)IworkbenchAction,所以得實(shí)現(xiàn)run方法。事實(shí)上,本系統(tǒng)的動(dòng)作類都和newDataSourceAction類似。本類運(yùn)行時(shí),先打開一個(gè)對(duì)話框,然后關(guān)閉數(shù)據(jù)源視圖、屬性視圖,再顯示這兩個(gè)視圖,這樣就起到刷新目的,其實(shí)現(xiàn)代碼如下:publicvoidrun(){ if(workbenchWindow==null){ return; } newDataSourceDialogdialog=newnewDataSourceDialog(Display .getCurrent().getActiveShell()); dialog.open(); IWorkbenchPagepage=workbenchWindow.getActivePage(); dataSourceView=workbenchWindow.getActivePage().findView(DatasourceView.ID); if(dataSourceView!=null){ page.hideView(dataSourceView); } attributeView=workbenchWindow.getActivePage().findView(AttributeView.ID); if(attributeView!=null){ page.hideView(attributeView); } if(page!=null) try{ page.showView(AttributeView.ID); page.showView(DatasourceView.ID); }catch(PartInitExceptione){ ErrorDialog.openError(workbenchWindow.getShell(),"打開視圖錯(cuò)誤", e.getMessage(),e.getStatus()); } }下面的代碼實(shí)現(xiàn)試連接的功能,根據(jù)不同的數(shù)據(jù)庫(kù),提供不同的連接字符串:button.addMouseListener(newMouseListener(){ publicvoidmouseDown(MouseEvente){ driverClass=makeClassDriver(); if(DataConn.getINSTANCE().isExit(DataSourceName,riverClass, dataURL.getText().trim(),userName.getText().trim(), userpassword.getText().trim(), sqlString.getText().trim())){ MessageDialog.openInformation(Display.getCurrent() .getActiveShell(),"連接數(shù)據(jù)庫(kù)","連接數(shù)據(jù)庫(kù)成功"); } } publicvoidmouseUp(MouseEvente){ //TODOAuto-generatedmethodstub } publicvoidmouseDoubleClick(MouseEvente){ //TODOAuto-generatedmethodstub } });試連接要用到com.xautreportdesign.util.DataConn,這是平常的數(shù)據(jù)庫(kù)連接方式,此處不寫代碼了。4.2.3新建報(bào)表在新建報(bào)表中,本系統(tǒng)只提供了設(shè)置報(bào)表的簡(jiǎn)單參數(shù),為處理方便,先把這些放入Preferernces中,這樣以后可以隨時(shí)快速訪問。Preferences是一種持久化API,其目的是為存儲(chǔ)少量數(shù)據(jù)提供一個(gè)高效的存儲(chǔ)設(shè)備。Preferences采用樹形結(jié)構(gòu),用Key/Value格式。本系統(tǒng)中用它來(lái)存儲(chǔ)正在編輯報(bào)表名稱,報(bào)表發(fā)布目錄等。StringdeployDirectry=preferences.get("deployDirectry",path .substring(1));上面說(shuō)明,如果前面的值為NULL,就用后面參數(shù)的值。在新建報(bào)表中,報(bào)表信息放在Preferences中,在保存時(shí)就可以訪問,得到當(dāng)前編輯的報(bào)表。代碼如下:Preferencespreferences=newConfigurationScope() .getNode("com.XautReportDduct"); preferences.put("name",fileName); preferences.put("rownum",rownum); if(Combo1.getText()!=null){ preferences.put("tempname",Combo1.getText().substring(0,Combo1.getText().lastIndexOf("."))); } try{ preferences.flush(); }catch(Exceptione){ e.printStackTrace(); }4.2.4編輯單元格編輯單元格就是在屬性視圖中編輯單元格,怎樣定位表格的單元格很重要。下面代碼中先得到鼠標(biāo)位置,然后找出它在表格中的行列,并把行列化為“A1”這樣的形式顯示在屬性視圖的Label1中。在編輯視圖中,用如下的代碼實(shí)現(xiàn)兩視圖互動(dòng):Pointpt=newPoint(event.x,event.y); finalTableItemitem=table.getItem(pt); if(item!=null){ intcolumn=-1; for(inti=0;i<=20;i++){ Rectanglerect=item.getBounds(i); if(rect.contains(pt)){ column=i; break; } } finalintcol=column; //數(shù)據(jù)綁定 IViewPartvp=getViewSite().getPage().findView( AttributeView.ID); AttributeViewav=(AttributeView)vp; LabeltitleLabel=av.getLabel1(); StringcolId=String .valueOf(table.getSelectionIndex()+1); titleLabel.setText("單元格:" +String.valueOf((char)(64+column))+colId);在屬性視圖中,是這樣根據(jù)Label1得到相應(yīng)的單元格的,把大寫字母化為一個(gè)數(shù)字,定位到單元格。代碼如下:IViewPartvp=getViewSite().getPage().findView(editAreaView.ID); editAreaVieweav=(editAreaView)vp; Tabletable=eav.getTable(); inti=label1.getText().indexOf(":"); StringtableLocal=label1.getText().substring(i+1); Stringcolid=tableLocal.substring(0,1); Stringrowid=tableLocal.substring(1); char[]char1=colid.toCharArray(); intk=char1[0]-64; TableItemitem=table.getItem(Integer.parseInt(rowid)-1);4.2.5生成電子表格這里要用到POI第三方JAR包。這個(gè)包可以生成、解析、直接編輯EXCEL文件。生成電子表格的代碼如下://前面已經(jīng)連接了數(shù)據(jù)庫(kù),現(xiàn)在就是要把數(shù)據(jù)填到EXCEL文件中。HSSFWorkbookwe=newHSSFWorkbook(); HSSFSheets=we.createSheet(reportName); we.setSheetName(0,"firstsheet"); HSSFRowrow=s.createRow(0);//創(chuàng)建一行 HSSFCell[]cell=newHSSFCell[colnum]; HSSFCellStylecellStyle=we.createCellStyle(); //對(duì)齊 cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); for(shorti=0;i<colnum;i++){ cell[i]=row.createCell(i); //將單元格定義成UTF_16編碼,這樣才能使輸出數(shù)據(jù)不會(huì)亂碼 cell[i].setEncoding(HSSFCell.ENCODING_UTF_16); cell[i].setCellValue(header[i]); cell[i].setCellStyle(cellStyle); } try{ rs.last(); intnum=rs.getRow(); rs.first(); for(inti=0;i<num&&rs.next();i++){ HSSFRowdatarow=s.createRow(i+1); HSSFCelldata[]=newHSSFCell[colnum]; for(shortk=0;k<colnum;k++){ Stringvalue1=null; if(DataSource[k].substring(0,2).equals("D:")){ //根據(jù)數(shù)據(jù)庫(kù)中的不同的類型調(diào)用不同的函數(shù) switch(remeta.getColumnType(colSort[k])){ caseTypes.CHAR: value1=rs.getString(colSort[k]); break; caseTypes.VARCHAR: value1=rs.getString(colSort[k]); break; caseTypes.BOOLEAN: value1=String.valueOf(rs .getBoolean(colSort[k])); break; caseTypes.DISTINCT: value1=String.valueOf(rs.getLong(colSort[k])); break; cas

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論