最新历史版本 :利用内置数据集实现自定义排序 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 概述编辑

1.1 问题描述

通过高级排序-自定义顺序可以直接在公式里面逐个定义每个数据项的顺序,但有时会使公式阅读起来困难且不易维护

这时可以通过使用「内置数据集」来自定义顺序,如下自定义地区的排序:

自定义排序.png

1.2 解决思路

在内置数据集中定义好数据项顺序,先通过数据集函数获取值,再通过 inarray() 函数返回单元格值在内置数据集中的位置。

2. 示例编辑

2.1 准备数据

1)新建普通报表,新建数据库查询 ds1,SQL 查询语句为:SELECT * FROM Sales。如下图所示:

1598856735204574.png

2)新建一个「内置数据集」,名为「自定义顺序」,添加一列「地区顺序」,按顺序输入数据如下图所示:

注:这里的「地区顺序」列的顺序即是最终的排序顺序。

1615772509869069.png

2.2 设计报表

将数据集 ds1 中的数据列拖入单元格,设计表格样式如下图所示:

image.png

2.3 设置扩展后排序

选中 A2 单元格,设置「扩展后排序」为「升序」,输入公式:inarray(A2, 自定义顺序.select(地区顺序))

公式说明如下表:

公式
说明
自定义顺序.select(地区顺序)数据集函数,返回「自定义顺序」数据集中「地区顺序」列的所有值
inarray()返回 A2 单元格当前值在「地区顺序」中的位置

步骤如下图所示:

2.4 效果预览

2.4.1 PC 端

保存报表,点击「分页预览」,效果如下图所示:

1598857178508423.png

2.4.2 移动端

App 端和 HTML5 端均支持,效果如下图所示:

image.png

3. 模板下载编辑

已完成模板可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\SpecialSubject\OrderReport\利用内置数据集实现自定义排序.cpt

点击下载模板:利用内置数据集实现自定义排序.cpt