遍历单元格

编辑
  • 文档创建者:印然
  • 浏览次数:5966次
  • 编辑次数:20次
  • 最近更新:Carly 于 2019-09-11
  • 1. 描述

    使用场景:有时候我们需要对报表每个单元格进行处理,如何在程序中遍历单元格呢?

    功能介绍:FineReport 中通过 Report的cellIterator() 方法获取 Report 中所有的单元格,这些单元格放在 Iterator 中,可以像遍历普通的 Iterator 对象一样遍历 Iterator 中的单元格,从而对单元格进行处理或作其他操作。

    根据需要您可以遍历所有单元格或者仅对部分单元格进行遍历,遍历方法我们在该文档中会一一说明,最后通过一个实际应用来展示遍历单元格的功效。


    2. 原理

    2.1 获取报表

    遍历单元格前我们需要获取单元格所在的容器 Report,我们以 Group.cpt 为例,如下所示:


    // 读取模板保存为WorkBook对象  
    workbook = TemplateWorkBookIO.readTemplateWorkBook("/doc/Primary/GroupReport/Group.cpt");


    2.2 遍历单元格


    // 遍历单元格  
    int col = 0, row = 0;
    byte direction = 0;
    java.util.Iterator it = report.cellIterator();
    while (it.hasNext()) {
        TemplateCellElement cell = (TemplateCellElement) it.next();
        // 获取单元格的行号与列号并互换  
        col = cell.getColumn();
        row = cell.getRow();
        cell.setColumn(row);
        cell.setRow(col);
        // 获取原单元格的扩展方向,0表示纵向扩展,1表示横向扩展  
        direction = cell.getCellExpandAttr().getDirection();
        if (direction == 0) {
            cell.getCellExpandAttr().setDirection((byte) 1);
        } else if (direction == 1) {
            cell.getCellExpandAttr().setDirection((byte) 0);
        }
        // 将改变后的单元格添加进新的WorkSheet中  
        newworksheet.addCellElement(cell);
    }


    3. 示例

    3.1 横纵向切换报表

    实现思路,首先通过输入的变量决定是否需要横纵向切换显示,若需要则遍历单元格,将单元格的行号与列号互换即可。

    Group.cpt 如下:


    将该模板读入程序,根据传入的参数 change 的值来进行横纵向控制

    • 当 change 没有值或者值为 0 时,为原显示效果;

    • 当 change 值为1,则切换报表行与列,最后转为网络报表。

    完整代码如下所示:

    https://git.fanruan.com/demo/example/src/release/10.0/src/main/java/com/fr/demo/ChangeRowAndCol.java


    3.2 发布与预览

    将编译生成的类文件 ChangeRowAndCol.class 放于报表工程%FR_HOME%\webapps\webroot\WEB-INF\classes\com\fr\demo下。

    启动服务器,在浏览器地址中输入地址

    http://localhost:8075/webroot/decision/view/report?viewlet=com.fr.demo.ChangeRowAndCol,结果如下图所示:


    浏览器地址中添加参数 &change=1 ,修改地址如下:

    http://localhost:8075/webroot/decision/view/report?viewlet=com.fr.demo.ChangeRowAndCol&change=1,结果如下图所示:


    这样,横纵向切换报表显示便实现了。

    关键字:行列转换


    附件列表


    主题: 二次开发
    标签: 暂无标签 编辑/添加标签
    如果您认为本文档还有待完善,请编辑

    文档内容仅供参考,如果你需要获取更多帮助,付费/准付费客户请咨询帆软技术支持
    关于技术问题,您还可以前往帆软社区,点击顶部搜索框旁边的提问按钮
    若您还有其他非技术类问题,可以联系帆软传说哥(qq:1745114201

    此页面有帮助吗?只是浏览 [ 去社区提问 ]