历史版本6 :根据分组设置页码 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 问题描述编辑

在对于分组模板进行页码统计时,希望页码统计只在当前分组进行即分组了就重新进行编码,如华东地区这个组内有三页数据而华北地区这个组内有两页数据,其效果如下:
222
222

2. 实现思路编辑

首先通过每页固定行数来计算每组所需的总页数,如上图中华东3页,华北2页;
其次使用当前页$$page_number减去之前组的总页数获得该页在当前组的页码,如上图华北的第一页数据所在$$page_number为4,减去之前组总页数3,就是该页在华北组的页码。

3. 示例编辑

假设已存在如下表样,其数据来源于FRDemo的销量表:
添加数据集ds1,SQL语句为SELECT * FROM 销量
222
3.1 按组分页及每页显示固定行数
按组分页:右击A3单元格,选择其他属性>行后分页
每页显示固定行数如10行:右击B3单元格,选择条件属性>添加条件>行后分页,当满足公式&B3 % 10 == 0时,该属性起作用;
重复标题行:将1~2行设为重复标题行,使其每页重复显示。
3.2 页码设置
首先我们要获取当前分组为第几个分组,在A1单元格中输入公式:=&A3,并将其左父格设置为A3单元格。
其次在B1单元格中输入公式:=roundup(count(B3) / 10, 0) + B1[A3:-1],获取当前分组的页码与上个分组的页码的总页码。
注:roundup(count(B3)/10,0)即获取当前分组的页码,roundup为向上取整, B1[A3:-1]为获取上一个A3分组内B1单元格的值。整个公式的意义在于获取当前分组的页码与上个分组的页码之和。
然后在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,则当前页码减去之前所有分组的总页数和。
A1、B1都为中间运算结果,可以设置单元格格式>其他属性>不预览单元格内容,不显示。

点击分页预览即可看到上图效果。