1. 概述
1.1 问题描述
通过高级排序-自定义顺序可以直接在公式里面逐个定义每个数据项的顺序,但有时会使公式阅读起来困难且不易维护
这时可以通过使用「内置数据集」来自定义顺序,如下自定义地区的排序:
1.2 解决思路
在内置数据集中定义好数据项顺序,先通过数据集函数获取值,再通过 inarray() 函数返回单元格值在内置数据集中的位置。
2. 示例
2.1 准备数据
1)新建普通报表,新建数据库查询 ds1,SQL 查询语句为:SELECT * FROM Sales。如下图所示:
2)新建一个「内置数据集」,名为「自定义顺序」,添加一列「地区顺序」,按顺序输入数据如下图所示:
注:这里的「地区顺序」列的顺序即是最终的排序顺序。
2.2 设计报表
将数据集 ds1 中的数据列拖入单元格,设计表格样式如下图所示:
2.3 设置扩展后排序
选中 A2 单元格,设置「扩展后排序」为「升序」,输入公式:inarray(A2, 自定义顺序.select(地区顺序))
公式说明如下表:
公式 | 说明 |
---|---|
自定义顺序.select(地区顺序) | 数据集函数,返回「自定义顺序」数据集中「地区顺序」列的所有值 |
inarray() | 返回 A2 单元格当前值在「地区顺序」中的位置 |
步骤如下图所示:
2.4 效果预览
2.4.1 PC 端
保存报表,点击「分页预览」,效果如下图所示:
2.4.2 移动端
App 端和 HTML5 端均支持,效果如下图所示:
3. 模板下载
已完成模板可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\SpecialSubject\OrderReport\利用内置数据集实现自定义排序.cpt
点击下载模板:利用内置数据集实现自定义排序.cpt