我对 Webi 很陌生,并且在创建变量时遇到了问题。我正在尝试检查每个实体旧帐号是否有超过 1 个电子邮件地址,以及是否有 1 个联系人姓名包含“年度报告”。因此,当我将每个实体遗留帐号标记为没有电子邮件时,只会提取没有包含“年度报告”的联系人姓名的那些。在上面的示例中,只有黄色组应该被称为没有电子邮件。现在他们都被拉进没有电子邮件。我尝试过使用 if 和 match,因为它们是我最熟悉的。有没有人有什么建议?
问问题
388 次
1 回答
0
有很多方法可以做到这一点。我将举一个使用两个变量的示例,但是您可以轻松地将它们组合成一个。
Has No Email Var=If(Match(Upper([Contact EmailAddress]); "NOEMAIL*"); 1; 0)
Annual Report Contact Name Var=If(Match(Upper([Contact Name]); "ANNUAL REPORT*"); 1; 0)
然后,您将应用包含两个组件的报告过滤器...
Has No Email Var = 1
AND
Annual Report Contact Name Var = 0
让我解释一些事情......
- Upper函数的目的是Match函数区分大小写。如果您知道您的电子邮件地址总是小写,那么您可以删除该Upper函数并使其与“noemail*”匹配。
- 重要的是,我在要查找的字符串的末尾只有一个星号(“*”)。这只会找到相应列值以该字符串开头的匹配项。如果您希望无论何时在正在搜索的列中的任何位置找到该字符串都为真,那么您将在两端加星号。
您还可以在查询过滤器中放置限制条件。但这里是事情可能会变得混乱的地方。在查询过滤器中,您可以选择匹配模式运算符。但是,通配符是不同的(“%”而不是“*”),并且您不要在搜索文本周围加上双引号。所以你会有这样的事情......
联系人电子邮件地址匹配模式 noemail%
和
联系人姓名与模式不同 年报%
我相信您注意到我没有将搜索文本转换为大写。在查询面板中,Web Intelligence区分大小写,并且可能会遵循源数据数据库的区分大小写。我们所有的数据库都不区分大小写,所以如果您的数据库区分大小写,您可能需要稍微尝试一下。或者只是按照我最初提出的创建变量和报告过滤器的方法进行。
如果您想要单个字符而不是多个字符的通配符(这是“*”和“%”的作用),您需要使用“?” 在您的变量定义或查询过滤器中的“_”中。
希望这可以帮助,
诺埃尔
于 2019-03-26T17:30:47.813 回答