反馈已提交

网络繁忙

利用内置数据集实现自定义排序

  • 文档创建者:axing
  • 编辑次数:3次
  • 最近更新:Alicehyy 于 2021-03-15
  • 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 单元格当前值在「地区顺序」中的位置

    步骤如下图所示:

    Snag_52f798e.png

    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

    附件列表


    主题: 报表专题
    • 有帮助
    • 没帮助
    • 只是浏览

    售前咨询电话

    400-811-8890转1

    在线技术支持

    在线QQ:800049425

    热线电话:400-811-8890转2

    总裁办24H投诉

    热线电话:173-1278-1526

    文 档反 馈

    鼠标选中内容,快速反馈问题

    鼠标选中存在疑惑的内容,即可快速反馈问题,我们将会跟进处理。

    不再提示

    10s后关闭