RangeMode - 指令碼與圖表函數
RangeMode() 尋找運算式或欄位中最常發生的值 (模式值)。
語法:
RangeMode(first_expr {, Expression})
傳回的資料類型: 數值
引數:
此函數的引數可能包含記錄間函數,它們會自行傳回值的清單。
引數 | 描述 |
---|---|
first_expr | 包含待測量之資料的運算式或欄位。 |
Expression | 包含待測量之資料範圍的選用運算式或欄位。 |
限制:
如果不只一個值有最高的出現頻率,則會傳回 NULL。
範例與結果:
範例 | 結果 |
---|---|
RangeMode (1,2,9,2,4) |
傳回 2 |
RangeMode ('a',4,'a',4) |
傳回 NULL |
RangeMode (null( )) |
傳回 NULL |
範例:
將範例指令碼新增至您的應用程式並予以執行。若要查看結果,將結果資料行中列出的欄位新增至您應用程式中的工作表。
RangeTab3:
LOAD recno() as RangeID, RangeMode(Field1,Field2,Field3) as MyRangeMode INLINE [
Field1, Field2, Field3
10,5,6
2,3,7
8,2,8
18,11,9
5,5,9
9,4,2
];
產生的表格顯示表格中各記錄的 MyRangeMode 傳回值。
RangeID | MyRangMode |
---|---|
1 | - |
2 | - |
3 | 8 |
4 | - |
5 | 5 |
6 | - |
運算式範例:
RangeMode (Above(MyField,0,3))
傳回 MyField 針對目前列和目前列上方兩列,所評估的三個結果中最常出現的值。若將第三個引數指定為 3,則 Above() 函數會傳回三個值 (上方需有足夠的列),並做為 RangeMode() 函數的輸入。
範例中使用的資料:
RangeTab:
LOAD * INLINE [
MyField
10
2
8
18
5
9
] ;
提示備註停用 MyField 的排序,確保範例如預期運作。
MyField | RangeMode(Above(MyField,0,3)) |
---|---|
10 | 傳回 10,因為上方沒有任何列,所以單一值是最常發生的值。 |
2 | - |
8 | - |
18 | - |
5 | - |
9 | - |