match - 指令碼與圖表函數
match 函數會比較第一個參數與所有後續參數,並傳回相符的運算式數字位置。比較區分大小寫。
語法:
match( str, expr1 [ , expr2,...exprN ])
本主題中的某些範例使用內嵌載入。如需詳細資訊,請參閱內嵌載入。
範例:使用 match 的載入指令碼
載入指令碼
您可以使用 match 載入資料子集。例如,您可以傳回函數中運算式的數值。然後您可以限制根據數值載入的資料。若沒有相符項目,Match 會傳回 0。在此範例中相符的所有運算式將會因此傳回 0,並且將會按照 WHERE 陳述式從資料載入中排除。
在資料載入編輯器中建立新的索引標籤,然後載入下列資料作為內嵌載入。在 Qlik Sense 中建立以下表格以查看結果。
Transactions: Load * Inline [ transaction_id, transaction_date, transaction_amount, transaction_quantity, customer_id, size, color_code 3750, 20180830, 23.56, 2, 2038593, L, Red 3751, 20180907, 556.31, 6, 203521, m, orange 3752, 20180916, 5.75, 1, 5646471, S, blue 3753, 20180922, 125.00, 7, 3036491, l, Black 3754, 20180922, 484.21, 13, 049681, xs, Red 3756, 20180922, 59.18, 2, 2038593, M, Blue 3757, 20180923, 177.42, 21, 203521, XL, Black ]; /* Create new table called Transaction_Buckets Create new fields called Customer, and Color code - Blue and Black Load Transactions table. Match returns 1 for 'Blue', 2 for 'Black'. Does not return a value for 'blue' because match is case sensitive. Only values that returned numeric value greater than 0 are loaded by WHERE statment into Transactions_Buckets table. */ Transaction_Buckets: Load customer_id, customer_id as [Customer], color_code as [Color Code Blue and Black] Resident Transactions Where match(color_code,'Blue','Black') > 0;
結果
色彩代碼藍色和黑色 | 客戶 |
---|---|
黑色 | 203521 |
黑色 | 3036491 |
藍色 | 2038593 |
範例 - 使用 match 的圖表運算式
圖表運算式 1
載入指令碼
在資料載入編輯器中建立新的索引標籤,然後載入下列資料作為內嵌載入。載入資料後,在 Qlik Sense 表格中建立以下的圖表運算式範例。
MyTable: Load * inline [Cities, Count Toronto, 123 Toronto, 234 Toronto, 231 Boston, 32 Boston, 23 Boston, 1341 Beijing, 234 Beijing, 45 Beijing, 235 Stockholm, 938 Stockholm, 39 Stockholm, 189 zurich, 2342 zurich, 9033 zurich, 0039];
以下表格中的第一個運算式會傳回 0 代表 Stockholm,因為 'Stockholm' 不包括在 match 函數的運算式清單中。這也會傳回 0 代表 'Zurich',因為 match 比較區分大小寫。
Cities | match( Cities,'Toronto','Boston','Beijing','Zurich') | match( Cities,'Toronto','Boston','Beijing','Stockholm','zurich') |
---|---|---|
Beijing |
3 |
3 |
Boston | 2 | 2 |
Stockholm | 0 | 4 |
Toronto | 1 | 1 |
zurich | 0 | 5 |
圖表運算式 2
您可以使用相符項目,以執行運算式的自訂排序。
按照預設,會按數字或字母排序欄,視資料而定。
Cities |
---|
Beijing |
Boston |
Stockholm |
Toronto |
zurich |
若要變更順序,請進行下列事項:
- 在屬性面板中開啟圖表的排序區段。
- 對於您要進行自訂排序的欄,關閉自動排序。
- 取消選取按數字排序和按字母排序。
-
選取按運算式排序,然後輸入類似下列項目的運算式:
=match( Cities, 'Toronto','Boston','Beijing','Stockholm','zurich')
Cities 欄的排序順序會變更。
Cities |
---|
多倫多 |
Boston |
Beijing |
Stockholm |
zurich |
您也可以檢視傳回的數值。
Cities | Cities & ' - ' & match ( Cities, 'Toronto','Boston', 'Beijing','Stockholm','zurich') |
---|---|
多倫多 | 多倫多 - 1 |
Boston | Boston - 2 |
北京 | Beijing - 3 |
斯德哥爾摩 | Stockholm - 4 |
蘇黎世 | zurich - 5 |