access IIf 函数

IIf 函数

Access for Office 365 Access 2019 Access 2016 Access 2013 Access 2010 Access 2007

注意: 我们希望能够尽快以你的语言为你提供最新的帮助内容。本页面是自动翻译的,可能包含语法错误或不准确之处。我们的目的是使此内容能对你有所帮助。可以在本页面底部告诉我们此信息是否对你有帮助吗?请在此处查看本文的英文版本以便参考。

根据表达式的求值,返回两部分之一。

在任何可以使用表达式的位置均可使用 IIf。您可以使用 IIf 确定另一个表达式为 True 还是 False。如果表达式为 True,则 IIf 返回一个值;如果为 False,则 IIf 返回另一个值。请指定 IIf 返回的值。

请参阅一些示例

语法

IIf ( expr , truepart , falsepart )

IIf 函数语法具有下列参数:

参数

说明

expr

必需。要计算其值的表达式。

truepart

必需。expr 为 True 时返回的值或表达式。

falsepart

必需。expr 为 False 时返回的值或表达式。

 

注解

尽管 IIf 只返回 truepart 和 falsepart 中的一个,但始终会对这两部分进行计算。因此,应当注意是否出现无谓的副作用。例如,如果计算 falsepart 时导致除数为零错误,那么即使 expr 为 True,也会产生错误。

示例

在窗体或报表上使用 IIf   假设您有一个客户表,该表包含名为国家/地区的字段。要在窗体,表示意大利语是否第一种语言的联系人。您可以添加控件,并在其控件来源属性中使用IIf如下所示:

=IIf([国家/地区]="意大利", "意大利语", "其他语言")

在窗体视图中打开窗体时,只要“国家/地区”值为“意大利”,该控件就显示“意大利语”,只要“国家/地区”值为其他值,该控件就显示“其他语言”。

在复杂表达式中使用 IIf   您可以使用任何表达式作为iif的任何部分。您可以"嵌套" IIf表达式,使您可以计算的一系列取决于表达式。若要继续前面的示例中,您可能想要测试多个不同的国家/地区值,然后显示相应的语言,具体取决于其存在值:

=IIf([国家/地区]="意大利", "意大利语", IIf([国家/地区]="法国", "法语", IIf([国家/地区]="德国", "德语", "其他语言")))

文本“其他语言”是最内层 IIf 函数的 falsepart 参数。由于每个嵌套 IIf 函数是包含它的 IIf 函数的 falsepart 参数,只有当所有 IIf 函数的 expr 参数计算结果为 False 时,才返回文本“其他语言”。

在另一示例中,假设您在图书馆工作。该图书馆的数据库中具有一个名为“借出”的表,表中包含名为“截止日期”的字段,该字段中包含有某本书的归还日期。您可以创建一个窗体,在控件中指示借出书籍的状态,方法是在该控件的“控件来源”属性中使用 IIf 函数,如下所示:

=IIf([截止日期]<Date(),"逾期",IIf([截止日期]=Date(),"今天到期","尚未到期"))

在窗体视图中打开该窗体时,如果“截止日期”小于当前日期,则该控件显示“过期”,如果该值正好是当前日期,则显示“今天到期”,否则显示“尚未到期”。

注意: 使用逻辑运算符,例如"和"或"或者"在IIf函数expr参数中,您必须用方括号将中的逻辑表达式Eval函数。请参阅下面的示例表。

在查询中使用 IIf   

IIf函数经常用于在查询中创建计算的字段。语法是相同的与异常,在查询中,您必须表达式以字段别名和冒号 (:),而不是以等号 (=)。若要使用上面的示例中,键入以下查询设计网格的字段行中:

语言: IIf([国家/地区]="意大利", "意大利语", "其他语言")

在本例中,“语言:”是字段别名。

有关创建查询和计算的字段的详细信息,请参阅文章创建简单的选择查询

在 VBA 代码中使用 IIf   

注意: 下面的示例说明使用此函数在 Visual Basic for Applications (VBA) 模块。有关处理 VBA 的详细信息,搜索旁边的下拉列表中选择开发人员参考,然后在搜索框中输入一个或多个术语。

以下示例使用 IIf 函数计算 CheckIt 过程的 TestMe 参数,如果数额大于 1000 则返回“大”;否则返回“小”。

Function CheckIt (TestMe As Integer)
    CheckIt = IIf(TestMe > 1000, "Large", "Small")
End Function

更多示例

表达式

结果

=IIf([机场代码]="ORD","芝加哥",IIf([机场代码]="ATL","亚特兰大",IIf([机场代码]="SEA","西雅图","其他")))

如果 [机场代码] 为“ORD”,则返回“芝加哥”。否则,如果 [机场代码] 为“ATL”,则返回“亚特兰大”。否则,如果 [机场代码] 为“SEA”,则返回“西雅图”。否则,返回“其他”。

=IIf([发货日期]<Date(),"已发货",IIf([发货日期]=Date(),"今天发货","未发货"))

如果 [发货日期] 早于今天的日期,则返回“已发货”。否则,如果 [发货日期] 等于今天的日期,则返回“今天发货”。否则,返回“未发货”。

=IIf([购买日期]<#1/1/2008#,"旧","新")

如果 [购买日期] 早于 1/1/2008,则返回“旧”。否则,返回“新”。

=IIf(Eval([电压] Between 12 And 15 And [安培] Between 0.25 And 0.3),"正常","未校准")

如果 [电压] 介于 12 和 15 之间,而 [安培] 介于 0.25 和 0.3 之间,则返回“正常”。否则,返回“未校准”。

=IIf(Eval([国家/地区] In ("加拿大","美国","墨西哥")),"北美地区","其他")

如果 [国家/地区] 为“加拿大”、“美国”或“墨西哥”,则返回“北美地区”。否则,返回“其他”。

=IIf([平均值]>=90,"A",IIf([平均值]>=80,"B",IIf([平均值]>=70,"C",IIf([平均值]>=60,"D","F"))))

如果 [平均值] 大于或等于 90,则返回“A”。否则,如果 [平均值] 大于或等于 80,则返回“B”。否则,如果 [平均值] 大于或等于 70,则返回“C”。否则,如果 [平均值] 大于或等于 60,则返回“D”。否则,返回“F”。

注意: 如果您使用IIf函数以在查询中创建计算的字段,替换等号 (=) 字段别名,并使用冒号 (:)。例如,状态: IIf ([发货日期] < Date (),"发运",IIf ([发货日期] = 日期 (),"发货今天"、"Unshipped"))

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值