您正在浏览的是 FineBI6.1 帮助文档,点击跳转至: FineBI5.1帮助文档

数据编辑中按指定规则进行排序

  • 产品级协助
  • 文档创建者:April陶
  • 历史版本:4
  • 最近更新:April陶 于 2025-01-09
  • 1. 概述

    1.1 问题描述

     如窗口函数等分析函数只能在组件内直接输出并使用。

    例如,RANK_AGG实现按照指定规则进行排序。对「合同付款类型」分组后,对组内不同「合同类型」金额降序排名,如下图所示:

    2025-01-08_16-43-50.png

    如果在「数据编辑」中直接输出。则提示「不支持直接输出聚合函数」。如下图所示:

    2025-01-07_10-47-23.png

    那么如何在数据编辑中,我们如何实现按照指定规则进行排序呢?

    2025-01-08_16-34-05.png

    1.2 问题原因

    RANK_AGG 和 WINDOW是聚合级别函数,直接基于分析视图进行计算。而数据编辑是基于明细的计算,无法为 RANK_AGG 和 WINDOW 提供有效视图。

    例如,问题描述中计算排名的公式为 :RANK_AGG([合同付款类型],[SUM_AGG(合同金额),"desc"],"UNIQUE")。依据「合同付款类型」分组后,分析视图中的维度栏拖入哪个字段,就按哪个字段降序排序。

    • 拖入「合同类型」,则按「合同付款类型、合同类型」依次分组汇总金额,求降序排名。

    • 拖入「客户名称」,则按「合同付款类型、客户名称」依次分组汇总金额,求降序排名。

    在「数据编辑」中需要固定分组字段,得到一个固定的排名结果。因此,在组件计算添加的 RANK_AGG 排名公式无法在数据编辑中直接使用。

    2025-01-08_17-24-41.png

    1.3 解决方案

     DEF 函数能够构建一个独立的视图,使用 DEF 嵌套窗口函数,可以为窗口函数提供明确的视图计算。

    数据编辑中「新增公式列」。

    公式 = DEF(聚合指标/窗口函数计算结果,[窗口函数依赖的视图维度1,窗口函数依赖的视图维度2])

            = DEF(RANK_AGG([合同付款类型],[SUM_AGG(合同金额),"desc"],"UNIQUE"),[合同付款类型,合同类型])

    2025-01-09_10-11-18.png

    具体的操作步骤请见下文示例。

    2. 操作步骤

    示例数据:合同事实表.xlsx

    2.1 处理数据

    1)在分析主题上传示例数据。详情请参见:5分钟上手FineBI

    2)对数据分组汇总。得到排序需要用的字段。如下图所示:

    2025-01-08_17-32-08.png

    3)对数据先按「合同付款类型」排序,再按合同金额降序。方便后续校验公式计算结果。如下图所示:

    2025-01-08_17-34-54.png

    2.2 输入公式

    4)输入计算公式=DEF(RANK_AGG([合同付款类型],[SUM_AGG(合同金额),"desc"],"UNIQUE"),[合同付款类型,合同类型])。如下图所示:

    步骤一用 RANK_AGG 计算排名对「合同付款类型」分组,然后对不同「合同类型」的金额降序排名,排名规则“连续排名”RANK_AGG([合同付款类型],[SUM_AGG(合同金额),"desc"],"UNIQUE")
    步骤二

    用DEF函数嵌

    目的是固定维度

    「合同付款类型、合同类型」

    DEF(步骤一公式,[合同付款类型,合同类型])

    2025-01-08_17-44-38.png

    2.3 效果查看

    如下图所示:

    2025-01-08_17-44-38.png


    附件列表


    主题: 进阶学习
    • 有帮助
    • 没帮助
    • 只是浏览
    中文(简体)

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

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

    不再提示

    10s后关闭



    AI

    联系我们
    在线支持
    获取专业技术支持,快速帮助您解决问题
    工作日9:00-12:00,13:30-17:30在线
    页面反馈
    针对当前网页的建议、问题反馈
    售前咨询
    采购需求/获取报价/预约演示
    或拨打: 400-811-8890 转1
    qr
    热线电话
    咨询/故障救援热线:400-811-8890转2
    总裁办24H投诉:17312781526
    提交页面反馈
    仅适用于当前网页的意见收集,帆软产品问题请在 问答板块提问前往服务平台 获取技术支持

    反馈已提交

    网络繁忙