反饋已提交

網絡繁忙

動態排名

1. 概述

1.1 預期效果

一般情況下,排名都是透過 SORT 函式 的方式實現。

但有時使用者需實現:在填報模式下,根據輸入值的不同來“動態改變”某一欄值的排名情況功能時,上面的方法就無法滿足了,預期效果如下圖:

2024-05-29_13-49-27.gif

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 端均支援,效果如下圖所示:

1.gif

3. 已完成範本

已完成範本,可參見:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doctw\Advanced\Cacuate_Between_Cells\動態排名.cpt

點選下載範本:動態排名.cpt


附件列表


主題: 報表專題
已經是第一篇
已經是最後一篇
  • 有幫助
  • 沒幫助
  • 只是瀏覽
  • 圖片不清晰
  • 用語看不懂
  • 功能說明看不懂
  • 操作說明太簡單
  • 內容有錯誤
中文(繁體)

滑鼠選中內容,快速回饋問題

滑鼠選中存在疑惑的內容,即可快速回饋問題,我們將會跟進處理。

不再提示

10s後關閉

獲取幫助
線上支援
獲取專業技術支援,快速幫助您解決問題
工作日9:00-12:00,13:30-17:30在线
頁面反饋
針對當前網頁的建議、問題反饋
售前咨詢
業務咨詢
電話:0933-790886或 0989-092892
郵箱:taiwan@fanruan.com
頁面反饋
*問題分類
不能為空
問題描述
0/1000
不能為空

反馈已提交

网络繁忙