×

ireport or

ireport(iReport 自定义 参数类型)

admin admin 发表于2022-09-04 22:17:20 浏览93 评论0

抢沙发发表评论

本文目录

iReport 自定义 参数类型


还在自己编写类?累不累呀,换用finereport吧,就知道什么叫做轻松的做报表了。
多数情况下,客户需要显示满足一定条件的部分数据,这便需要用到参数。参数设计实际上就是一个动态的过滤数据的过程,便于用户与数据能够实时交互。
FineReport内置了一个默认的参数界面,用户可在内置的界面中,调整参数的位置,并通过控件设置得到各种不同的数据选择方式。
在此,我们在上张报表的基础上介绍参数查询界面的设计过程。
1. 参数界面布局
点击参数界面,进入参数编辑界面,在新建模板和数据集章节,我们在ds1数据集中定义了参数“地区”。
可以在参数界面的右侧下方区域看到我们所有定义好的参数,点击全部添加,将会使用默认的布局形成参数界面。
用户可以根据需要将参数界面调整到自己喜欢的样式。
2. 参数控件风格
将地区参数控件类型改为下拉框,如下图:
选中下拉框控件,在右上方属性表中,设置下拉框的数据字典,选择数据库表》FRDemo》销量,实际值和显示值都为地区字段:

用ireport怎么实现总计和小计


  可以用Jaspersoft iReport。
  Variable -》 Variable的属性的Variable class设为java.lang.Integer, Calculation设为Sum -》
总计:Variable的属性的Variable Expression设为DataSet的域。如:$F{XXX}
小计:Variable的属性的Variable Expression设为DataSet的域,并用三元表达式筛选出集计的值 如:$F{XXX}==‘B’? $F{YYY} : 0
  设个变量,resettype为group,calculationType为count.。只要灵活应用分组+交叉表+子报表,就能行。
  通过变量可以设置你要分组累计的具体列,做法:Document--》Variables--》Variable Name处填写一个自定义名称,Variable Class Type处选择累计的信息的数据类型,Calculation Type选择Sum求和。Reset Type处选择分组或别的方式重新设置值得依据。IncreamentType不填。Variable Expression填写你要累计的对象表达式。Initial Value Expression处填写数据类型的初始化对象。--》最后在调用的地方学则Variables,从中选择刚刚配置好的变量,即可。
  报表中经常需要进行合计了,这里我介绍一下如何使用变量进行合计:可以添加一个变量,将Calculation Type设置为Sum,Reset Type里面有None,Report,Page,Column,Group,这个很好理解,就是在相应的范围重新设置值,比如选择Group,也就是说当组 发生变化时,该变量的值就重新初始化,Increment Type里面也有这几个选择项,注意的是,当选择None,就表示只要换了一行,就把对应的值相加,所以一般我们应该选则None.Varialbe Expression的值设置为 new Integer($F{COST}),表示对Cost的值求和,Initial value Expression 设置为new java.lang.Integer(0),表示每次从0开始,比如前面Calculation Type设置为Group时,就表示如果换组时,这个变量的初始值为0.
  最后要做的只是把这个变量拖到报表上.

ireport 做好之后怎么看效果


不知道ireport的方法是不是和我用的finereport一样哎,连接好数据源之后,将所需要的拖拽到设计器中制作成相应的报表,如果是想要查看效果的话,有一个预览,可以进行分页预览,填报预览,数据分析,就可以查看做好的效果了。
-ireport

请问一下iReport中的字段、参数、变量的区别,要怎么使用


你真是幸运,我前几天才研究的IREPORT
首先确定你的数据库建立好了
IREPORT是这样的,你可以在IREPORT里设置好jrxml(或者jsper)
这东西里面已经包含了数据库链接方式,驱动,以及表名,字段名,查询语句,还有相对应的显示方式(当然是以pdf,html等方式显示)
然后你把jasper或者jrxml放在java目录下,在代码中载入使用
比如
你可以在ireport里设置数据库链接,并且给一个主键来查询
select * from user where name=’xxx’,完成其他ireport设置后把jasper文件放到对应的java project目录下
然后你在java代码中载入这个jasper,然后传入这个name的参数
执行后,jasper会根据这个参数执行sql语句,然后取出字段,根据你事先设定的显示方式生成pdf或者html或者其他格式的报表
如果你只是要在jsp里面显示一下字段而已,那么你就直接在jsp里取数据库吧
ireport是报表工具,你不做报表就不需要用ireport
有什么问题再问吧
你也可以不用数据库链接,那么你首先在ireport中手动设定字段
生成jasper后在项目的代码中你必须主动为这个jasper输入对应字段的值,然后执行即可
ireport的作用就是生成PDF或者HTML等,没有其他作用了,不知道你想干什么
-or

ireport的使用技巧


  1)配置数据源.
  选择 DATA-资料/来源 (估计这个是台湾或者香港或者海外华人翻译的菜单),然后在出现的界面选择NEW.
  点击next后,按照出现的下图,选择JDBC驱动以及数据库链接路径,输入用户和密码.(假设安装的时候有hr方案).
  2)新建一个文档或者说是新建一张报表,菜单是档案-》开启新档 (CTRL+N)典型的台湾翻译.
  “字段数“原文是column count,其实翻译为”列数“更好一些,意思是一个页面按照纵向分为几个部分,例如有输出为
  id, name .如果你选择字段数=2,那么输出的就是形如:
1 Jack
2 Mike
3 Tony
4 BeckHam
5 Rose
  3)设置需要的表格区域.
  默认的可用区域包括(这在所有的报表中英文都是band):TITLE,PAGEHEADER,COLUMNHEADER,DETAIL,COLUMNFOOTER,PAGEFOOTER,LASTPAGEFOOTER,SUMMARY.
  不是所有的表格区域都是需要的,常用就是title,columnheader,detail,pagefooter,summary我们可以把不需要的隐藏起来. 在报表空排区域右键单击,在弹出的菜单上选择“栏的属性“,把bandheight参数设置为你需要的值,如果不想显示该区域(或者是band或者是栏)可以设置BANDHEIGHT=0.
  4) 输入sql
  建议用快捷的图标,就是最上一排,大概中间靠右的地方有个圆柱体的图标(鼠标移动到上面会出现database的提示),
  点击一下,在出现的窗口输入sql语句如下:
  
  5)摆放字段和设置标题
  有工具还是好的,否则工具就没有什么意义了. 点击菜单预览-》docking panes-》document structure,然后你自己摆放好文档结构栏板,在出现的栏板上展开fileds节点,如图:
  注意,这里很重要的: 选中“姓名“,按住左键不放,拖到detail 栏目上,然后依次拖动其它三个字段.
  顺便说一下,这样的操作对于document structure 中的variables和parameters中的成员也是成立的,对于LIBRARY中变量也是一样的(就是上图的下面部分,显示“page number“等等的地方).
  至于对齐这些报表元素,不用说了吧? 看看最下面一栏的快捷按钮你应该明白的.
  从最上面一排快捷按钮中找到“不回动的文字“(别扭的翻译),其实就是文本标签. 先点击左键然后放开,然后移动鼠标到columnheader区域,再按住左键不放,在区域中拉出一个矩形区域,则可在该区域放上一个文本标签.依次操作放上其它三个,也可发挥ctrl+c,ctrl+v的功能完成其它三个.
  6)设置pagefooter和summary内容.
  通常我们都会在页脚放置诸如 “x页/共y页“的字样. 按照前面所说的拖动方法,从library栏板中拖动“page x of y“到pagefooter区域. 然后你可以分别修改需要显示的内容为:“第 “ + $V{PAGE_NUMBER} + “ 页 “ ,“共“ + $V{PAGE_NUMBER} + “页“.
  7)第一次预览.
  
  8)加sql参数条件和计算行数.
  通常我们的SQL都会有条件存在的,首先我们假设要查询月薪》=特定数值的员工的报表,则先在DOCUMENT STRUCTURE 栏板(或者面板)中右键单击,选择菜单 add-》parameter,
  如果你自己不知道应该选择什么类型,但是又需要知道新的参数是什么类型,那么最好的办法是查看detail区域上月薪字段的数据类型,一看是java.math.BigDecimal,那么好,就设置为java.math.BigDecimal.
  
  如果是字符串类型,一般你就不要new然后再转换了,直接输入字符串即可,不过需要加上引号.
  修改sql(如前,点击圆柱体图标即可),加上以下语句:
  where salary》=$P{salary} ,注意$P表示参数的前缀,$V表示变量的前缀,$F表示字段,名称则在中括号输入.
  在summary 栏板中添加变量report_count,然后修改数据类型为字符串,并修改表达式为:“累计人数:“+$V{REPORT_COUNT}.
  9)试验一个简单的ireport 折线图
  做图是比较有意思的地方,因为美啊! 必须说明的是,例子用的ireport 是2.0.0.
  本来想下载jasper的说明,一看要钱,还是$的,就打消了主意,还是自己来吧。
  做折线图是比较常见的,没有什么特别的,不过有几点还是需要注意的:
  1)构建可用的sql语句,这里有很奇怪的技巧要求,也许以后jasper会修改它们的解析机制.
  2)设置图数据集,包括x,y轴的参数,
  3)把chart图放置在正确的打印区域(band)
  9.1 正确的sql
  首先从sql说起,由于在设置series expression(不知道如何翻译更加妥贴一些,暂时翻译为分组表达式)时候是务必要有值的,如果用x或者y的值去作为表达式,直觉来说是不恰当的,所以想想是不是用个常量了,结果还真是.
  例句:select mons,cjl,10 N from test_value where jjr=’LZF’ ORDER BY MONS.
  以mons作为x轴,以cjl为y轴,那么N就是连线变量了.N是什么值什么类型不重要,可以是字符串可以是有理数.
  这样就可以形成了报表的字段变量$F{MONS},$F{CJL},$F{N}
  如果你想多画几条线,那么就用一个会变化的字段来替代N,譬如可以假设有sql如下:
  select mons,cjl,jjr n from test_value ORDER BY MONS.
  9.2 设置x,y等图象要素
  在图上右键点击,在弹出的菜单上选择“char properties“,然后在弹出的窗口中选择“char data“页面,然后选择“char data“页面中的“details“子页,这是关键的地方,然后点击“ADD“按钮,在下图中填入:
  
  “Label expression(optional)“可以不要输入,这是可选项目。“item hyperlink“可以不要理睬,这是用于设置元素超链用的,暂时不要搞这么复杂的.
  然后就是设置图的显示属性,如下图(这是选择“chart properties“时候首先就出现的部分):
  
  基本名词解析:
  chart title expression 图标题表达式
  chart subtitle expression 图副标题表达式
  show legend 显示图例
  category axis label expression x轴标签表达式(意译了)
  value axis label expression y轴标签表达式
  9.3 放置在正确的区域
  对于chart务必不能放在detail区域,否则会有奇怪的显示,不知道是本人不精熟还是ireport的bug(也不能要求太多,毕竟这是个非盈利产品,除了它的部分资料).
如果放置在detail区域,那么当sql结果集存在多个行的时候,图就会被画对应的次数,譬如有N行,则图也会出现N个一样的。 所以通常放置在汇总区域(即summary band),不要越界.
最后,用ireport自带的预览工具,可以看到下图:
  一条线的,series是固定值。
-ireport

ireport怎么生成jasper文件


在“建立”菜单下点击编译,默认的是会在你的安装目录下自动生成一个.jasper文件,若报表有错误则会编译失败,并在console窗口提示错误信息。

怎么将ireport的数据类型进行转换


其实ireport一般在里面设置字段的格式都是String类型,如果从数据库里有不同的类型读出时,你可以在后台进行转换。尽量不要把转换类型的任务交给ireport来处理,容易出错。另外ireport里设置F字段、P参数、V变量都可以选择类型的的。你在Variable Type那里可以进行设置。
-or

ireport闪退


Ireport-5.6.0及更早的版本只支持JDK1.7及更低的版本,环境变量配置的不是1.7及以下的话,可以修改配置文件指定jdk路径,修改方法如下:
Ireport安装路径下的/etc/ireport.conf文件:
#jdkhome=“/path/to/jdk“
改为
jdkhome=“F:\JDK\JDK_1.7.80“ (JDK1.7的安装路)
记得删前面的注释符号#
-ireport

解决ireport显示中文问题


显示中文的正确设置
1 配置:
将iTextAsian.jar和iTextAsianCmaps.jar置于l项目lib中iTextAsian.jar;
2.在ireport中依次点击“工具”、“选项”,将图片下方复选框打钩;

3.依次选中可能出现汉字的文本框,进行如下设置
font name:宋体
PDF font name: STSong-Light;
pdfEncoding =UniGB-UCS2-H
PdfEmbedded :打钩选择
-or

如何利用ireport实现打印条码标签


  1、打开ireport,新建一个文档,用鼠标点击图标拖拽到文档里,这里不累述ireport的使用方法,ireport的使用说明书可以到网上下载。

  2、双击

,打开它的属性框,选择图片栏,在图片表达式里输入条码转换的方法,可以查阅如下代码:
  3、注意图片表达式类选择java.awt.Image

  

  

  

  /*
2  * Copyright (C) 2005 - 2006 JasperSoft Corporation. All rights reserved. 
3  * http://www.jaspersoft.com.
4  *
5  * Unless you have purchased a commercial license agreement from JasperSoft,
6  * the following license terms apply:
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License version 2 as published by
10  * the Free Software Foundation.
11  *
12  * This program is distributed WITHOUT ANY WARRANTY; and without the
13  * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
14  * See the GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, see http://www.gnu.org/licenses/gpl.txt
18  * or write to:
19  *
20  * Free Software Foundation, Inc.,
21  * 59 Temple Place - Suite 330,
22  * Boston, MA USA 02111-1307
23  *
24  *
25  *
26  *
27  * BcImage.java
28  * 
29  * Created on 20. April 2004, 13:21
30  *
31  */
32 
33 package it.businesslogic.ireport.barcode;
34 
35 /**
36  *
37  * @author Heiko
38  */
39 
40 import java.awt.image.*;
41 import net.sourceforge.barbecue.*;
42 import net.sourceforge.barbecue.linear.ean.UCCEAN128Barcode;
43 
44 public class BcImage {
45     private static net.sourceforge.barbecue.Barcode bc = null;
46     
47     public static net.sourceforge.barbecue.Barcode getBarcode() {
48         return bc;
49     }
50     
51         public static BufferedImage getBarcodeImage(int type, Object  aText, boolean showText, boolean checkSum) {
52             return getBarcodeImage(type, aText, showText, checkSum,““,0,0);
53         }
54         
55     public static BufferedImage getBarcodeImage(int type, Object  aText, boolean showText, boolean checkSum, String  applicationIdentifier, int width, int height) {
56         // 2of7, 3of9, Bookland, Codabar, Code128, Code128A, Code128B, Code128C, Code39, EAN128, EAN13, GlobalTradeItemNumber, Int2of5, Int2of5, Monarch, NW7, PDF417, SCC14ShippingCode, ShipmentIdentificationNumber, SSCC18, Std2of5, Std2of5, UCC128, UPCA, USD3, USD4, USPS
57 
58         String  text = new StringBuffer ().append(aText).toString();
59 
60         try {
61             switch (type) {
62                                 case 0: return null;
63                                 case 1: bc = BarcodeFactory.create2of7(text); break;
64                 case 2: bc = BarcodeFactory.create3of9(text, checkSum); break;
65                 case 3: bc = BarcodeFactory.createBookland(text); break;
66                 case 4: bc = BarcodeFactory.createCodabar(text); break;
67                 case 5: bc = BarcodeFactory.createCode128(text); break;
68                 case 6: bc = BarcodeFactory.createCode128A(text); break;
69                 case 7: bc = BarcodeFactory.createCode128B(text); break;
70                 case 8: bc = BarcodeFactory.createCode128C(text); break;
71                 case 9: bc = BarcodeFactory.createCode39(text, checkSum ); break;
72                 case 10: bc = BarcodeFactory.createEAN128(text); break;
73                 case 11: bc = BarcodeFactory.createEAN13(text); break;
74                 case 12: bc = BarcodeFactory.createGlobalTradeItemNumber(text); break;
75                 case 13: bc = BarcodeFactory.createInt2of5(text, checkSum); break;
76                 case 14: bc = BarcodeFactory.createMonarch(text); break;
77                 case 15: bc = BarcodeFactory.createNW7(text); break;
78                 case 16: bc = BarcodeFactory.createPDF417(text); break;
79                 case 17: bc = BarcodeFactory.createSCC14ShippingCode(text); break;
80                 case 18: bc = BarcodeFactory.createShipmentIdentificationNumber(text); break;
81                 case 19: bc = new UCCEAN128Barcode(UCCEAN128Barcode.SSCC_18_AI, text, checkSum); break; //BarcodeFactory.createSSCC18(text); break;
82 case 20: bc = BarcodeFactory.createStd2of5(text, checkSum); break;
83                 case 21: bc = new UCCEAN128Barcode(applicationIdentifier, text, checkSum); break; //BarcodeFactory.createUCC128(applicationIdentifier, text); break;
84 case 22: bc = BarcodeFactory.createUPCA(text); break;
85                 case 23: bc = BarcodeFactory.createUSD3(text, checkSum); break;
86                 case 24: bc = BarcodeFactory.createUSD4(text); break;
87                 case 25: bc = BarcodeFactory.createUSPS(text); break;
88                                 case 26: bc = new net.sourceforge.barbecue.linear.code39.Code39Barcode(text, checkSum, true); break;
89             }
90             
91                         if (width 》 0) bc.setBarWidth(width);
92                         if (height 》 0) bc.setBarHeight(height);
93             bc.setDrawingText(showText);
94             return net.sourceforge.barbecue.BarcodeImageHandler.getImage(bc);
95         }
96         catch (Exception  e) {
97             e.printStackTrace();
98             //generate a runtime exception, invalid value passed. 
99 //the user must be notified if fail 
100 throw new RuntimeException (e.getMessage());
101             //return null;
102 }
103     }
104 }-ireport