历史版本14 :行分栏 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 描述编辑

有时我们会遇到列数很少,但是扩展出很多行的报表,这种报表窄而长,预览或打印时会有很大的一片空白区域,不美观且浪费纸张。为了节省空间、增加美观性,FineReport报表可以通过分栏将报表进行行方向或者列方向的分栏显示。

如下图行分栏后效果所示,数据是从上到下扩展,超过20行,就在第2列中显示,并且每列数据都有列表头,整个表格有一个大标题。
222

2. 操作步骤编辑

2.1 数据准备

新建普通报表,新建数据集ds1:SELECT * FROM 人员变动表

2.2 模板设计

如下图,在报表主体上设计报表:

1)将相关数据列拖动到对应单元格,纵向扩展;

2)B3 单元格父格为 C3,其值为公式seq(),作用是对 C3 列进行顺序编号,其详细使用方法请查看 行序号


另:报表设计时,大标题必须要覆盖整个分栏区域。

预览效果如下,可以报表每页右侧都有很多的空白区域,浪费空间:

222


2.3 分栏设置

如上图,报表右侧还有很多空白区域,那么就可以设置行分栏,将左侧超过固定行的数据挪到右侧。这里我们设置每一栏显示 20 行数据(不包括表头)。

在菜单栏中,选择模板>报表分栏,“开启”分栏:

1)分栏样式:“行分栏”;

2)超过 X 行分栏:每栏最多 X 行数据,超过行数的数据分到下一栏,本示例为每栏 20 行数据;

3)分栏成 X 列:根据数据总行数(不含表头)N 确定,每栏行数=总行数 N / 列数 X,该选项在只要求分成固定栏数时使用,本示例不使用;

4)分栏区域:根据示例设计的模板,需要分栏的“分栏数据”为“A3:E3”;行表头需要在分栏后重复,行表头所在行序号为 2,所以“复制行序列”为“2”。如下图:

5)补充空白行:当最后一栏数据不足 20 行时,如果需要将不足的添补为空白行,则勾选此项;如果不需要添补,则此项不勾选。


2.4 分栏时的特别要求

纵向扩展时,由于栏数不定,设置上面的分栏后,一页可能会显示出多栏,甚至最右边的栏会显示不全,而我们往往希望每页能够固定显示两栏或三栏。

此时我们需要保证,设计报表时:

1)如果每页显示两栏或三栏,左侧设计报表所占的总列宽最多不超过分页线内宽度的 1/2 或 1/3,如下图示例的显示两栏情况;

2)如果左侧设计报表的宽度不能再小(或再大),就需要调整需要分页线的位置(参见调整 页面设置),以保证页面宽度能显示希望的栏数,而不至于显示不全。

3. 效果预览编辑

3.1 PC 端预览效果

保存模板,选择分页预览,实现效果如上图。

注:分栏只适用于分页预览。

3.2 移动端预览效果

1)App:

222

2)H5:

222

4. 已完成模板编辑

模板效果在线查看请点击:行分栏.cpt

已完成的模板可参考%FR_HOME%\webroot\WEB-INF\reportlets\doc\Advanced\行分栏.cpt

点击下载模板