efa's blog

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

          導(dǎo)航

          <2007年1月>
          31123456
          78910111213
          14151617181920
          21222324252627
          28293031123
          45678910

          統(tǒng)計(jì)

          常用鏈接

          留言簿(18)

          我參與的團(tuán)隊(duì)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          Bi report

          dba

          info security

          other

          perl

          php

          python

          tech blogs

          tech websites

          最新隨筆

          搜索

          積分與排名

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          了解jasperreport ,讓web報(bào)表跑得更好

          一、為什么是jasperreport
                   很簡單兩點(diǎn):
             ?。薄∶赓M(fèi)
             ?。病≡诖蠖鄶?shù)開源產(chǎn)品中最能滿足本人/公司的需求.
                 如果要一句話總結(jié)那么就是 "適合就好!" ,其次再想插一句"其實(shí)jasperreport可以做得更好,只是缺少大家去發(fā)現(xiàn)。" 

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

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

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

          <table>
          <tr>
           
          <td>
             
          <table>
              
             
          </table>
             
          <br/> <!--兩個(gè)br分行標(biāo)記-->
             
          <br/>
             
          <table>
              
             
          </table>
           
          </td>
          </tr>
          </table>


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

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

           

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

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

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

          6.交叉報(bào)表

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

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

          1.動(dòng)態(tài)列
           
          2.可設(shè)列寬度

          3.CSS設(shè)計(jì)
            


           

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

          評(píng)論

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

          有點(diǎn)關(guān)于jasperreport的問題請教
          我下載了jasperreport1.1.0的代碼,其中有許多DEMO但是我卻運(yùn)行不起來,老是報(bào)如下錯(cuò)誤不知是何原因,但0.68版本卻可以,錯(cuò)誤如下 :
          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] 嚴(yán)重: 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

          希望能指點(diǎn)一下,不勝感激,我的郵箱:kswdgx◎163.com
            回復(fù)  更多評(píng)論   

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

          good  回復(fù)  更多評(píng)論   

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

          打印問題設(shè)置為cm后依然存在  回復(fù)  更多評(píng)論   

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

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

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

          如何分組?  回復(fù)  更多評(píng)論   

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

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

          我的環(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包里的沖突,經(jīng)排查是xercesImpl.jar包的問題,移出lib即可,這個(gè)包記得在我用hibernate時(shí)也沖突過,以后還得提防著他點(diǎn)兒^^  回復(fù)  更多評(píng)論   

          主站蜘蛛池模板: 尚义县| 蓬安县| 光山县| 旬邑县| 金平| 青川县| 上栗县| 阿坝| 观塘区| 缙云县| 富民县| 周至县| 保靖县| 湖北省| 固原市| 大足县| 海原县| 施甸县| 濮阳市| 黄大仙区| 哈巴河县| 济宁市| 水富县| 岳西县| 天祝| 虞城县| 司法| 宽甸| 乐业县| 阿拉善左旗| 德阳市| 满洲里市| 驻马店市| 九龙城区| 扶沟县| 大竹县| 陇南市| 兴和县| 蚌埠市| 崇义县| 青阳县|