1. 概述
1.1 預期效果
但有時,用戶需實現:在填報模式下,根據輸入值的不同來“動态改變”某一列值的排名情況功能時,上面的方法就無法滿足了,預期效果如下圖:
1.2 實現思路
通過報表内置的 rank() 函數來變換實現。
RANK(number,ref,order):返回一個數在一個數組中的秩。(如果把這個數組排序,該數的秩即爲它在數組中的序号。)
參數說明:
number:所求秩的數(可以是 Boolean型,true=1,false=0)
ref:可以是數組,引用,或一系列數,非實數的值被忽略處理(接受 Boolean 型,true=1,false=0)
order:指定求秩的參數,非零爲升序,零爲降序
2. 示例
2.1 準備數據
新建普通報表,新建内置數據集,新增兩個字段爲:「姓名」、「分數」,類型分别爲「字符串」、「整數」。如下圖所示:
2.2 設計報表
将字段拖入對應的單元格中,設計表格如下圖所示:
1)給 C2 單元格添加 數字控件
2)D2 單元格輸入公式:B2+C2
3)E2 單元格輸入公式:rank(D2, D2[!0], 0),其中 D2[!0] 表示 D2 擴展出來的所有單元格
注:其中 B2 ,C2 默認需爲數字格式,才可實現排名,若 B2 ,C2 單元格爲其他格式,則會出現下圖情況:
此時在 D2 單元格輸入公式 sum(B2+C2),則可解決排名亂碼問題。
2.3 保存預覽
1)PC端
保存模板,點擊「填報預覽」,效果同 1.1 節預期效果一緻。
2)移動端
App 端和 H5 端均支持,效果如下圖所示:
3. 已完成模板
已完成模板,可參見:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\Advanced\Cacuate_Between_Cells\動态排名.cpt
點擊下載模板:動态排名.cpt