倪問尹,陳順平,尹 鋒
NI Wen-yin, CHEN Shun-ping, YIN Feng
(長沙大學,長沙 410003)
報表是用表格、圖表等格式來動態顯示數據的一種方式,即指定數據以指定運算方法得出結果后,以指定樣式在指定頁面上的特殊表現形式。目前,Web報表已成為報表發展的一個主流方向[1]。目前國內外主流Web報表產品,如水晶報表(Crystal Report)、Style Report、Brio、MSTR、和勤報表、用友華表等,其基本思路都是利用特定文件格式生成報表,通用性、兼容性較弱。應此,格式轉換的設計與實現成為通用WEB報表服務的基礎,也是解決開放式架構和系統集成的核心問題。
本系統基于.NET平臺開發,根據用戶自定義在服務器端實現報表格式自動轉換,將報表XML表現后利用服務器端的組件解析生成HTML文檔,利用XML本身強大的可擴展性、可復用性和自解釋性實現通用的WEB報表服務[3~5]。系統采用.NET Framework用于生成、部署、運行 XML Web Services 和應用程序,使用SQL數據庫實現數據存儲,使用 C#語言進行程序編輯,具備在線定制與在線運行功能。
影響報表樣式變化的因素有應用領域、用戶需求和個人愛好等,其最終都可以歸結為以下幾種報表模型的組合:列表、分組報表、嵌套報表、交叉報表、圖形報表等。
常見的報表的結構布局為表頭(Report Header)、表尾(Report Footer)、頁眉(Page Header)、頁腳(Page Header)、分組(Group)、主體(Detail)、合計(Summary)等。
按照報表元素的層次,組成報表的元素可分成報表根元素、容器元素和實體元素三種。
從報表對象到格式報表文件之間就是一個規則映射過程[6,7]。其主要思路是:將從應用程序中導入的應用對象與從規則庫中導入的規則子集進行匹配,按匹配成功的規則執行動作,將結果輸出給應用程序。基于基本映射技術實現的系統稱作規則引擎,即根據規則中包含的指定過濾條件,判斷能否匹配運行時刻的實時條件來執行規則中所規定的動作。四個基本要素是:信息元Information Unit(包含特定事件所有信息的對象,如信息元類型、相關規則集、通用屬性及相關信息等[8])、信息服務Information Services、規則集Rule Se、隊列管理器Queue Manager(管理來自不同信息服務的信息元對象)。其實現如圖1所示。

圖1 規則映射技術的實現
設計報表類TxtReport封裝報表的屬性和對報表的操作,通過該報表對象實現對報表的訪問、修改、發布等操作,并封裝對象序列化的過程。將設計的報表保存為.txt格式的報表定義文件的過程,即報表對象序列化的過程[9]。其UML圖如圖2所示。

圖2 報表類TxtReport的UML圖
其中,主要屬性包括:ReportName(報表名稱)、PageWidth(報表頁寬度)、PageHeight(報表頁高度)等。
主要操作方法包括:CreatNewReport()創建一個空的報表、SaveToFile()保存當前報表、DeplayReport(path:string)將當前報表發布到指定目錄path中等。
將所有報表實體元素的共同屬性和操作方法抽象出來,構造一個報表元素基類TxtObject。各種具體的報表實體元素類繼承自TxtObject,擁有獨特屬性,并且重寫了三個重要函數:
1)Draw():在報表設計界面上畫出該報表元素;
2)LoadFromStream(Stream:TStream):加載序列化后的報表實體元素對象;
3)SaveToStream(Stream:TStream):保存該報表實體元素對象,即序列化。
TxtObject類的UML圖如圖3所示,每個報表元素類中都封裝了對象序列化的過程(子類的UML圖略)。

圖3 TxtObject類的UML圖
1)根元素<MsReport attribute=”value”></MsReport>
報表定義文件中的根元素,用MsReport標識,每個報表定義文件中有且只有一個根元素。其中attribute表示屬性名,value表示屬性值。
2)容器元素
區域是報表的重要組成部分,一個完全的報表包括若干個區域,每個區域可作為報表的一個容器元素,包括表頭、分組、報表主體、總結等幾個區域[10]。
3)實體元素
用標識rectangle、staticText、textField、chart等來表示報表實體元素。
針對兩種格式的報表(ILASSⅡ中底層數據.txt格式的報表和 WEB發布時通用的.xml格式報表) 定義映射規則以實現這兩種報表格式之間的轉換[11]。使用DOM技術,對.XML格式的報表定義文件在內存中構造DOM樹,從樹根開始,深度遍歷每個結點,根據結點的屬性逆向構造報表對象和報表中的每一個實體元素。當整個DOM樹遍歷完成后,也就構造了整個報表對象,然后將逆向構造成的報表對象序列化得到.TXT格式的報表文件。
假設txt文件中有以下字段:Name:***Version:*.*.* Size:10 M Repo:installed Summary:5 - Beta Description:********。在通用WEB報表服務中轉換為xml格式過程如下:


本文設計實現的通用WEB報表服務系統中報表格式的轉換,主要是針對目前WEB報表存在的問題,基于.NET平臺的體系結構和技術特點開發,實現了其它報表系統不支持的在線定制報表的功能。通過規則映射實現的報表通用化,即解決了不同報表格式的轉換,避免了因環境改變而不得不重新開發報表的問題,同時這種轉換具有很強的可擴展性,只需將映射規則在規則庫中擴展并修改報表格式轉換模塊的接口,便可以實現更多格式報表的定制與解析。
[1]陳明.分布計算應用模型[M].北京:科學出版社,2009.04:219-220.
[2]張有明,張科,高赟.基于Access的信息管理系統開發實踐[J].電化教育研究,2007(02):65-68.
[3]Lawrence, Racoon.The space efficiency of XML.Information and Software Technology,2004,46.
[4]Kristensen,Anders.Formsheets and the XML forms language.Computer Networks,1999,31.
[5]Michalis Petropoulos, Yannis Papakonstantinou, Vasilis Vassalos.Building XML query forms and reports with XQForms.Computer Networks,2002,39.
[6]王李軍,陶明亮,張曙,莫琪葉.面向業務規則引擎研究[J].軟件技術與數據庫,2007(24):65-68.
[7]彭磊.規則引擎原理分析[J].福建電腦,2007(9):42-45
[8]蔡文,楊春燕.面向業務規則引擎研究[J].智能系統學報,20094(3):234-238.
[9]李佳,付強,丁寧,等.C#開發技術大全 [M].北京:清華大學出版社,2009:538-540.
[10]張文啟.基于AJAX的可復用Web報表系統的設計及實現[D].中山大學,2009:12-13.
[11]郭昕,武娟.基于C#語音的EPSW與CASS數據格式轉換[J].北京測繪,2009(4):78-84.