LookUp - 脚本函数
Lookup() 用于查找已经加载的表格,并返回与在字段 match_field_name 中第一次出现的值 match_field_value 对应的 field_name 值。表格可以是当前表格或之前加载的其他表格。
语法:
lookup(field_name,
match_field_name, match_field_value [, table_name])
返回数据类型: 双
参数:
参数
field_name |
需要返回值的字段的名称。 输入值必须为字符串(例如引用的文字)。 |
match_field_name |
要在其中查找 match_field_value 的字段的名称。 输入值必须为字符串(例如引用的文字)。 |
match_field_value |
要在 match_field_name 字段中查找的值。 |
table_name |
要在其中查找值的表格的名称。输入值必须为字符串(例如引用的文字)。
如果省略了 table_name,假定为当前表格。
|
信息注释引用当前表格的参数,不带引号。要引用其他表格,须使用单引号将参数括起来。
限制:
搜索顺序即为加载顺序,除非表格为复杂操作的结果(如联接),在这种情况下顺序并未很好地定义。field_name 及 match_field_name 必须为相同表格中的字段,由 table_name 指定。
如果未找到匹配值,则返回 NULL。
加载脚本
将以下数据作为数据加载编辑中的内联加载载入,以创建以下示例。
ProductList: Load * Inline [ ProductID|Product|Category|Price 1|AA|1|1 2|BB|1|3 3|CC|2|8 4|DD|3|2 ] (delimiter is '|'); OrderData: Load *, Lookup('Category', 'ProductID', ProductID, 'ProductList') as CategoryID Inline [ InvoiceID|CustomerID|ProductID|Units 1|Astrida|1|8 1|Astrida|2|6 2|Betacab|3|10 3|Divadip|3|5 4|Divadip|4|10 ] (delimiter is '|'); Drop Table ProductList;
有关使用内联加载的详细信息,请参见内联加载。
创建可视化
在 Qlik Sense 工作表中创建表格可视化。将字段 ProductID、InvoiceID、CustomerID、Units 和 CategoryID 添加至表格。
结果
结果表
ProductID |
InvoiceID |
CustomerID |
单位: |
CategoryID |
1 |
1 |
Astrida |
8 |
1 |
2 |
1 |
Astrida |
6 |
1 |
3 |
2 |
Betacab |
10 |
2 |
3 |
3 |
Divadip |
5 |
2 |
4 |
4 |
Divadip |
10 |
3 |
解释
样本数据使用以下格式的 Lookup() 函数:
Lookup('Category', 'ProductID', ProductID, 'ProductList')
首先加载 ProductList 表格。
Lookup() 函数用于构建 OrderData 表格。它将第三个参数指定为 ProductID。这是用于在 ProductList 的第二个参数'ProductID'中查找值的字段,用单引号括起来表示。
此函数返回“Category”的值(ProductList 表格中),然后加载作为 CategoryID。
drop 语句用于从数据模型删除 ProductList 表格(因为不再需要),从而保留所得的 OrderData 表格:
信息注释
Lookup() 函数的用法非常灵活,可以用于访问先前加载的所有表格。但是,与 Applymap() 函数相比,它的速度相对较慢。