Qlik Sense : Lookup函数

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;复制代码到剪贴板

开始加载数据

ProductList << d865949f-f290-44e2-b3d0-f0efcc6ee92c

获取的行数: 4

OrderData << a164d9e4-a6e5-4eeb-99a4-0e952cebce22

获取的行数: 5

Creating search index

搜索索引创建已成功完成

创建可视化

在 Qlik Sense 工作表中创建表格可视化。将字段 ProductID、InvoiceID、CustomerID、Units 和 CategoryID 添加至表格。

结果

Qlik Sense : Lookup函数_第1张图片

结果表
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() 函数相比,它的速度相对较慢。

你可能感兴趣的:(Qlik,Sense,QlikSense,Lookup)