1. 概述
1.1 预期效果
在对于分组模板进行页码统计时,希望页码统计只在当前分组进行即分组了就重新进行编码,如华东地区这个组内有三页数据而华北地区这个组内有两页数据,其效果如下:
1.2 实现思路
首先通过每页固定行数来计算每组所需的总页数,如上图中华东 3 页,华北 2 页;
其次使用当前页 $$page_number 减去之前组的总页数获得该页在当前组的页码,如上图华北的第一页数据所在 $$page_number为4,减去之前组总页数 3,就是该页在华北组的页码。
2. 示例
2.1 报表设计
1)添加模板数据集 ds1,输入SQL 语句SELECT * FROM 销量
2)并将 B3 单元格设置为列表展示,如下图所示:
2.2 设置按组分页
1)右击 A3 单元格,选择单元格属性>其他>行后分页,如下图所示:
2)每页显示固定行数如 10 行:右击 B3 单元格,选择条件属性>添加条件>行后分页,当满足公式&B3 % 10 == 0时,该属性起作用;
3)重复标题行:将 1~2 行设为重复标题行,使其每页重复显示。
2.3 页码设置
1)首先我们要获取当前分组为第几个分组,在 A1 单元格中输入公式:=&A3,并将其左父格设置为 A3 单元格。
2)其次在B1单元格中输入公式:=roundup(count(B3) / 10, 0) + B1[A3:-1],获取当前分组的页码与上个分组的页码的总页码。
注:roundup(count(B3)/10,0)即获取当前分组的页码,roundup 为向上取整, B1[A3:-1]为获取上一个 A3 分组内 B1 单元格的值。整个公式的意义在于获取当前分组的页码与上个分组的页码之和。
3)然后在 E1 单元格中输入公式:=if(A1= 1, $$page_number + "/" + roundup(count(B3) / 10, 0), $$page_number - B1[A3:-1] + "/" + roundup(count(B3) / 10, 0))
注:$$page_number + "/" + roundup(count(B3) / 10, 0)表示当前页在当前分组的第几页。整个公式的意义在于如果 A1 即当前分组为 1,就直接为当前页/当前分组总页数;如果不为 1,则当前页码减去之前所有分组的总页数和。
4)A1、B1 都为中间运算结果,可以设置单元格格式>其他属性>不预览单元格内容,不显示。
2.4 效果预览
2.4.1 PC 端
保存模板后,点击「分页预览」,详情参见本文 1.1 节。
2.4.2 移动端
App 与 HTML5 端效果相同,如下图所示: