Jasperreports+jaspersoft studio学习教程(七)- Table组件的使用

7.1 设计报表模板

 

7.1.1 新建模板DemoReport5.jrxml,去掉不需要的Band,保留Title,Page Header,Detail 1 , PageFooter。将组件Table拖入到Detail1 中,跳出Dataset窗口。选择 Create .. ,然后Next




7.1.2 给Dataset命名。选择 Createnew dateset ... ,然后Next







7.1.3 只保留Column Header,然后 Finish




7.1.4 点击Detail中的Table组件进入到Table界面中。




7.1.5 在Column Header中右键Column1 选择Create Column After,生成4个Column




7.1.6 一般表头都是 合并列的复杂表头。选择Column1 右键 -》 Group Columns




在Columns[1]中的Column1右键Create Column after ,显示如下:



将其他三个也如此操作




7.1.7 将组件Text Field 拖入表格中,并设置表头名




7.1.8 在dateset1中新建Field属性,并拖入到Table的Detail中,设置字体样式(这里自定义命名Filed,且注意类型)




7.1.9 返回到Main Report ,新建Fields 命名为table Data,设置Class为JRBeanCollectionDataSource,注意写全路径,新建一个Field为Date,Class为String





7.1.10 点击Main Report 的Detail中的Table,显示Properties后,点击DataSet,选中Use a JRDatasource expression,将新建tableData写入。





保存模板,并复制到JasperWeb项目中。



7.2 编写Servlet注入数据源


7.2.1 新建Fields类和ModelTableSource类如下:

package com.jasper.bean;

public class Fields {
	
	private String field1;
	private String field2;
	private String field3;
	private String field4;
	private String field5;
	private String field6;
	private String field7;
	private String field8;

//get 和 set方法省略

}

package com.jasper.bean;

import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;

public class ModelTableSource {
	/**
	 * 注入table组件的数据源
	 */
	private JRBeanCollectionDataSource tableData;
	/**
	 * 当前时间(查询时间)
	 */
	private String date;
// get和set方法省略

}


7.2.2 新建JasperServlet5 ,doGet内容如下:


protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        Map<String,Object> parameters = new HashMap<String,Object>(16);
		
		String jrxmlPath = request.getServletContext().getRealPath("/")+"/jrxml/DemoReport5.jrxml";
		//由jrxml文件编译后生产jasper文件的路径
		String jasperPath = request.getServletContext().getRealPath("/")+"/jasper/DemoReport5.jasper";
		
		FileInputStream isRef = null;
		ServletOutputStream sosRef = null;
		
		try {
			//编译jrxml生产jasper文件
			JasperCompileManager.compileReportToFile(jrxmlPath, jasperPath);
			
			isRef = new FileInputStream(new File(jasperPath));
			sosRef = response.getOutputStream();
			//组装list数据源
			List<Fields> list = new ArrayList<Fields>();
			for(int i = 1 ; i <= 20; i++) {
				Fields fields = new Fields("field"+i,"field"+(i+1),"field"+(i+2),"field"+(i+3),"field"+(i+4),"field"+(i+5),"field"+(i+6),"field"+(i+7));
				list.add(fields);
			}
			ModelTableSource mts = new ModelTableSource();
			mts.setDate(new SimpleDateFormat("yyyy-MM-dd").format(new Date()));
			mts.setTableData(new JRBeanCollectionDataSource(list));
			List<ModelTableSource> mlist = new ArrayList<ModelTableSource>();
			mlist.add(mts);
			//new JRBeanCollectionDataSource(list)  以javaBean为数据源注入报表数据
			JasperRunManager.runReportToPdfStream(isRef, sosRef, parameters, new JRBeanCollectionDataSource(mlist));
			response.setContentType("application/pdf");
		} catch (JRException e) {
			
			e.printStackTrace();
		}finally {
			sosRef.flush();
			sosRef.close();
		}
	}


7.2.3 启动tomcat并访问







<think>好的,我现在需要解决用户在Jaspersoft中如何让平均数保留两位小数的问题。首先,我应该回忆一下Jaspersoft的基本操作,特别是处理数值格式的部分。用户提到的是平均数,可能在报表使用了一些计算字段或者汇总函数,所以需要格式化这些数值的输出。 我记得在Jaspersoft Studio中,格式化数字通常是通过设置字段的Pattern属性来实现的。例如,对于数字字段,可以在属性面板中找到Pattern选项,然后选择或输入格式模式,比如“#,##0.00”来保留两位小数。但不确定这是否适用于计算后的平均值,比如通过变量计算得到的值。可能需要检查变量的设置,确保其值类型正确,比如设置为BigDecimal或其他数值类型,这样格式化才会有效。 另外,可能存在的情况是用户使用了文本字段直接显示数值,这时候可能需要使用表达式来转换格式,例如使用new DecimalFormat("#0.00").format($V{avgVariable}),不过这种方法依赖于Java的DecimalFormat类,需要确认JasperReports是否支持这样的表达式,或者是否有更推荐的方式。 还有一种可能性是在SQL查询中直接处理平均数的格式,例如在数据库查询时使用ROUND函数,比如ROUND(AVG(column), 2),但这样会将四舍五入后的值传递给报表,可能影响后续计算,所以通常建议在报表层处理格式,而不是在数据层。 用户可能会遇到的常见问题包括:设置Pattern后小数位没有显示,可能是因为字段的数据类型不是数值型,或者Pattern格式输入错误。需要提醒用户检查数据类型是否正确,以及Pattern是否应用到了正确的字段或变量上。 另外,可能需要指导用户如何定位到需要格式化的字段:在Design视图中选择对应的文本框,查看属性中的Text Field属性,设置Pattern。如果是图表中的数值,可能需要到图表的数据标签或数值格式设置中进行调整。 最后,为了确保用户能够正确操作,应该分步骤说明,例如:选择字段,找到属性面板,设置Pattern为两位小数,预览验证结果。同时,提醒一些注意事项,比如数值类型必须正确,避免使用字符串类型导致格式化无效。</think>在JasperSoftJasperReports)中,若需将平均数保留两位小数,可通过以下步骤实现: --- ### **步骤 1:定位目标字段** - 在Design视图中,找到需要显示平均数的字段(可能是`Variable`、`Text Field`或图表中的数据标签)。 --- ### **步骤 2:设置数值格式** 1. **直接设置Pattern属性** - 右键点击字段 → 选择 **Properties** → 找到 **Text Field** 标签页。 - 在 **Pattern** 输入框中填写格式代码: ```plaintext #,##0.00 ``` - 示例:数值 `1234.5` 将显示为 `1,234.50`。 2. **通过表达式动态格式化(可选)** 若需更灵活控制,可使用表达式: ```plaintext new java.text.DecimalFormat("#,##0.00").format($V{your_avg_variable}) ``` - 将此表达式填入字段的 **Expression** 属性(需启用“**Markup**”为`none`)。 --- ### **步骤 3:验证数据类型** - 确保字段或变量的数据类型为数值型(如`java.lang.Double`、`BigDecimal`),而非字符串。 --- ### **特殊情况处理** - **图表中的数值**: 在图表属性中,找到数据标签的格式设置(如`Value Format`),应用相同Pattern。 - **SQL中直接计算平均值**: 若在SQL查询中使用`AVG()`函数,可配合`ROUND`函数: ```sql SELECT ROUND(AVG(column_name), 2) AS avg_value FROM table_name ``` --- ### **注意事项** - 若小数位未生效,检查字段是否为数值类型。 - 避免在数据库层四舍五入,除非明确需要修改原始数据。 通过以上步骤,即可确保平均数在JasperSoft报表中始终显示两位小数。
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值