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 |