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;
结果
Color Code Blue and Black | Customer |
---|---|
Black | 203521 |
Black | 3036491 |
Blue | 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];
下面表格中的第一个表达式为 Stockholm 返回 0,因为 'Stockholm' 未包括在 match 函数中的表达式列表内。它也为 'Zurich' 返回 0,因为 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 |
---|
Toronto |
Boston |
Beijing |
Stockholm |
zurich |
您还可查看返回的数值。
Cities | Cities & ' - ' & match ( Cities, 'Toronto','Boston', 'Beijing','Stockholm','zurich') |
---|---|
Toronto | Toronto - 1 |
Boston | Boston - 2 |
Beijing | Beijing - 3 |
Stockholm | Stockholm - 4 |
zurich | zurich - 5 |