二次开发、程序中遍历单元格, ChangeRowAndCol
有时候我们需要对报表每个单元格进行处理,如何在程序中遍历单元格呢?FineReport中通过Report的cellIterator()方法获取Report中所有的单元格,这些单元格放在Iterator中,可以像遍历普通的Iterator对象一样遍历Iterator中的单元格,从而对单元格进行处理或作其他操作。
根据需要您可以遍历所有单元格或者仅对部分单元格进行遍历,遍历方法我们在该文档中会一一说明,最后通过一个实际应用来展示遍历单元格的功效。
1. 实现原理
1.1 获取报表
遍历单元格前我们需要获取单元格所在的容器Report,我们以Group.cpt为例,如下
1.2 遍历所有单元格
1.3 遍历部分单元格
2. 具体实例
2.1 横纵向切换报表
实现思路,首先通过输入的变量决定是否需要横纵向切换显示,若需要则遍历单元格,将单元格的行号与列号互换即可。
Group.cpt如下
将该模板读入程序,根据传入的参数change的值来进行横纵向控制,当change没有值或者值为0时,为原显示效果;若change值为1,则切换报表行与列,最后转为网络报表,完整代码如下
将编译生成的类文件放于报表工程WEB-INF\classes\com\fr\demo下,启动服务器,在浏览器地址中输入如
http://localhost:8075/WebReport/ReportServer?reportlet=com.fr.demo.ChangeRowAndCol,结果如下
浏览器地址中添加参数,修改地址如下
http://localhost:8075/WebReport/ReportServer?reportlet=com.fr.demo.ChangeRowAndCol&change=1,结果如下
这样,横纵向切换报表显示便实现了。
返回顶部