efa's blog

          以用戶角度出發(fā),你就已經成功一半了.

          導航

          <2005年11月>
          303112345
          6789101112
          13141516171819
          20212223242526
          27282930123
          45678910

          統(tǒng)計

          常用鏈接

          留言簿(18)

          我參與的團隊

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          Bi report

          dba

          info security

          other

          perl

          php

          python

          tech blogs

          tech websites

          最新隨筆

          搜索

          積分與排名

          最新評論

          閱讀排行榜

          評論排行榜

          了解jasperreport ,讓web報表跑得更好

          一、為什么是jasperreport
                   很簡單兩點:
              1 免費
              2 在大多數(shù)開源產品中最能滿足本人/公司的需求.
                 如果要一句話總結那么就是 "適合就好!" ,其次再想插一句"其實jasperreport可以做得更好,只是缺少大家去發(fā)現(xiàn)。" 

                       在erp軟件開發(fā)中一套強大易用的報表工具還是相當重要的地位,在這里我只針對一些日常業(yè)務報表.
                        jasperreport + ireport 報表套裝在普通的報表中已做得很不錯:流水賬式的,分組報表都可以輕松實現(xiàn).在這里提出的是一些相對特別以及少用到的報表設計問題.
                       當前版本 : jasperreport  1.1.0
                                           ireport  : 0.5.2

          二、問題與解決
                     
          1.操作
                  初用ireport 設計報表(特別是早期的版本)感覺還是比較原始,相對于birt 類似于在 Dreamweaver中畫table 式的設計還是有點差距.但新版本(0.5.2)中也有不小的改善,增加了很多快速對齊,格式化的工具欄以及快捷操作方式.通過結合這些操作還算是方便了不少.

          2.分頁
                     剛接觸jasper report ,無論是看其官方的example還是自己動手設計報表,  html view 總給人很深的印象:"怎么字體那么小,而且實際打印一下,分頁功能并沒真正實現(xiàn)"
                  經過客戶一輪的抗義,最終還是下定決心去修補一下,
            其實jasper report 原理還是挺簡單:
              它默認的分頁方式是能過一輪的高度計算,再用兩個<br>就以為了事了.

          <table>
          <tr>
           
          <td>
             
          <table>
              
             
          </table>
             
          <br/> <!--兩個br分行標記-->
             
          <br/>
             
          <table>
              
             
          </table>
           
          </td>
          </tr>
          </table>


                 解決方案:
                 好在jasperreport還提供了很好的擴展方案.它允許我們自定義分頁方式(就是說在兩頁/table之間能讓我們放自己的代碼),自己定義betweenPagesHtml 就OK了,可以能過CSS定義分頁.在這里,我就直接改它代碼算了.大家可以自己選擇.
              
          net.sf.jasperreports.engine.export.JRHtmlExporter

          <!--CSS代碼-->
          pageEnd 
          {page-break-after:always}

           

          if (betweenPagesHtml == null)
                                  
          {
                                      writer.write(
          "<br class=\"pageEnd\">");   // 原來是兩個 <br/>
                                  }
           else
                                  
          {
                                      writer.write(betweenPagesHtml);
                                  }

          3. 打印
                分頁解決后可以發(fā)現(xiàn)當報表預覽時真的能一頁一頁分得很好.卻又發(fā)現(xiàn)了一個問題.報表明顯不能滿一張A4張大小(ireport 設計選擇的是A4紙張),疑惑了一際子,其實不能算是BUG.
             ireport 報表屬性中明顯(21 * 29.7 CM) 一張A4紙的大小,為什么HTML出來的效果卻明顯小的那么多了.其實這與計算機的分辨率有關
             計算機中的分辨率,普遍是72 象素/英寸,而打印機普通是300象素/英寸.
             jasperreport 與ireport 默認單位是px,我猜想如果用CM做單位的話可以解決這個問題.但在這里我們的做法是盡量加大報表設計時的寬度與高度.另一個要注意的是記得將所有頁邊距設為0,因為這些設置在打印的時候已在IE/瀏覽器中設定了,不用重復.
             
          4.分欄
                以前沒多注意,但剛用ireport新版本時可以發(fā)現(xiàn)在報表屬性設計的時候可以設置欄.這下子如果當報表主體部分列數(shù)不多時實現(xiàn)分欄顯示,以節(jié)省紙張.

          5.斑馬線式顯示報表主體
             
          有時我們想讓報表更美化,讓用戶更方便地觀看數(shù)據(jù),可以設置兩種色相隔.這種效果在jasperreport 中的example中有demo一下,大家如果想學習可以下載看看.

          6.交叉報表

             關于jasperreport的交叉報表設計網上還是有不小的討論,而真正實現(xiàn)的不多.我觀察過大多用jasperreport實現(xiàn)都是偽交叉報表.并不是真正實現(xiàn)真正的動態(tài)行與列.
             其實在jaspert report下載包中還是有個交叉報表的實現(xiàn)example(crosstabs),只不過據(jù)我了解,現(xiàn)在ireport還不能實現(xiàn)設計.只能通過手工寫jrxml文件實現(xiàn).本人小試一下,還是挺不錯的.
           

          三、待研究
           通過繼承net.sf.jasperreports.engine.export.JRHtmlExporter ,還是能擴展不小的功能.例如用CSS格式化,可以大大減小代碼量,動態(tài)列/可設列寬度大大增強我們的報表功能.
           現(xiàn)本人初部實現(xiàn)100%寬度,不再用jasperreport中hardcode列度等等,以下三點還有待時間去跟進:)

          1.動態(tài)列
           
          2.可設列寬度

          3.CSS設計
            


           

          posted on 2005-11-28 20:35 一凡@ITO 閱讀(13516) 評論(6)  編輯  收藏 所屬分類: Bi report Tools

          評論

          # re: 了解jasperreport ,讓web報表跑得更好 2006-02-15 22:02 kswdgx

          有點關于jasperreport的問題請教
          我下載了jasperreport1.1.0的代碼,其中有許多DEMO但是我卻運行不起來,老是報如下錯誤不知是何原因,但0.68版本卻可以,錯誤如下 :
          Buildfile: H:\study\report\jasperreports-1.2.0-project\jasperreports-1.2.0\demo\samples\shapes\build.xml
          compile:
          [jrc] Compiling 1 report design files.
          [jrc] 2006-2-15 21:42:18 org.apache.commons.digester.Digester getParser
          [jrc] 嚴重: Digester.getParser:
          [jrc] org.xml.sax.SAXNotRecognizedException: Feature: http://apache.org/xml/features/validation/dynamic
          [jrc] at org.apache.crimson.parser.XMLReaderImpl.setFeature(Unknown Source)
          [jrc] at org.apache.crimson.jaxp.SAXParserImpl.setFeatures(Unknown Source)
          [jrc] at org.apache.crimson.jaxp.SAXParserImpl.<init>(Unknown Source)
          [jrc] at org.apache.crimson.jaxp.SAXParserFactoryImpl.newSAXParserImpl(Unknown Source)
          [jrc] at org.apache.crimson.jaxp.SAXParserFactoryImpl.setFeature(Unknown Source)
          [jrc] at org.apache.commons.digester.parser.XercesParser.configureXerces(XercesParser.java:185)
          [jrc] at org.apache.commons.digester.parser.XercesParser.newSAXParser(XercesParser.java:138)
          [jrc] at org.apache.commons.digester.ParserFeatureSetterFactory.newSAXParser(ParserFeatureSetterFactory.java:71)
          [jrc] at org.apache.commons.digester.Digester.getParser(Digester.java:692)
          [jrc] at org.apache.commons.digester.Digester.getXMLReader(Digester.java:899)
          [jrc] at org.apache.commons.digester.Digester.parse(Digester.java:1647)
          [jrc] at net.sf.jasperreports.engine.xml.JRXmlLoader.loadXML(JRXmlLoader.java:238)
          [jrc] at net.sf.jasperreports.engine.xml.JRXmlLoader.loadXML(JRXmlLoader.java:225)
          [jrc] at net.sf.jasperreports.engine.xml.JRXmlLoader.load(JRXmlLoader.java:213)
          [jrc] at net.sf.jasperreports.engine.xml.JRXmlLoader.load(JRXmlLoader.java:167)
          [jrc] at net.sf.jasperreports.engine.xml.JRXmlLoader.load(JRXmlLoader.java:151)
          [jrc] at net.sf.jasperreports.engine.JasperCompileManager.compileReportToFile(JasperCompileManager.java:107)
          [jrc] at net.sf.jasperreports.ant.JRAntCompileTask.compile(JRAntCompileTask.java:398)
          [jrc] at net.sf.jasperreports.ant.JRAntCompileTask.execute(JRAntCompileTask.java:252)
          [jrc] at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:275)
          [jrc] at org.apache.tools.ant.Task.perform(Task.java:364)
          [jrc] at org.apache.tools.ant.Target.execute(Target.java:341)
          [jrc] at org.apache.tools.ant.Target.performTasks(Target.java:369)
          [jrc] at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1216)
          [jrc] at org.apache.tools.ant.Project.executeTarget(Project.java:1185)
          [jrc] at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:40)
          [jrc] at org.eclipse.ant.internal.ui.antsupport.EclipseDefaultExecutor.executeTargets(EclipseDefaultExecutor.java:32)
          [jrc] at org.apache.tools.ant.Project.executeTargets(Project.java:1068)
          [jrc] at org.eclipse.ant.internal.ui.antsupport.InternalAntRunner.run(InternalAntRunner.java:423)
          [jrc] at org.eclipse.ant.internal.ui.antsupport.InternalAntRunner.main(InternalAntRunner.java:137)
          File : H:\study\report\jasperreports-1.2.0-project\jasperreports-1.2.0\demo\samples\shapes\ShapesReport.jrxml ...

          BUILD FAILED
          H:\study\report\jasperreports-1.2.0-project\jasperreports-1.2.0\demo\samples\shapes\build.xml:30: java.lang.NullPointerException

          Total time: 2 seconds

          希望能指點一下,不勝感激,我的郵箱:kswdgx◎163.com
            回復  更多評論   

          # re: 了解jasperreport ,讓web報表跑得更好 2006-04-03 15:51 kelo

          good  回復  更多評論   

          # re: 了解jasperreport ,讓web報表跑得更好 2006-08-29 17:07 Tedeum

          打印問題設置為cm后依然存在  回復  更多評論   

          # re: 了解jasperreport ,讓web報表跑得更好 2006-12-22 17:45 linger2008

          請教,如何能把jasper 生成的多個excel文件,合并為多個sheet的一個文件?我的郵箱 gll1976@yahoo.com.cn  回復  更多評論   

          # re: 了解jasperreport ,讓web報表跑得更好 2006-12-30 11:30 linger2008

          如何分組?  回復  更多評論   

          # re: 了解jasperreport ,讓web報表跑得更好 2007-04-26 18:18 caoyuan

          @kswdgx
          我也碰到類似的問題了,一直google不到解決辦法,今兒解決了,所以就在這兒回復您吧,雖然看起來我們一問一答的時間差的很遠^^

          我的環(huán)境是win2003 sp2,jdk1.5.0_11,resin-3.1.0

          [17:54:11.296] Compiling _jsp/_jsp/_compile__jsp.java
          [17:54:12.171] Digester.getParser:
          [17:54:12.171] org.xml.sax.SAXNotRecognizedException: http://apache.org/xml/feat
          ures/validation/dynamic
          [17:54:12.171] at com.caucho.xml.parsers.XmlSAXParserFactory.setFeature(XmlSAXP
          arserFactory.java:93)
          [17:54:12.171] at org.apache.commons.digester.parser.XercesParser.configureXerc
          es(XercesParser.java:185)
          [17:54:12.171] at org.apache.commons.digester.parser.XercesParser.newSAXParser(
          XercesParser.java:138)

          只看到這兒,很容易聯(lián)想到是xml解析器jar包里的沖突,經排查是xercesImpl.jar包的問題,移出lib即可,這個包記得在我用hibernate時也沖突過,以后還得提防著他點兒^^  回復  更多評論   

          主站蜘蛛池模板: 孟连| 大兴区| 凤山市| 临西县| 贵港市| 阳新县| 阿拉善盟| 海丰县| 哈巴河县| 根河市| 安阳县| 云梦县| 古蔺县| 武胜县| 闵行区| 定陶县| 孝昌县| 高密市| 黄梅县| 古田县| 垣曲县| 万全县| 雅安市| 仙居县| 灵武市| 蓬安县| 宁波市| 墨竹工卡县| 商洛市| 南昌市| 南溪县| 冀州市| 周口市| 晋宁县| 东丽区| 巴林右旗| 广丰县| 韶关市| 汶川县| 绥江县| 榆林市|