IIf 函数
时 间:2015-05-18 14:47:48
作 者:杨雪 ID:42182 城市:南京
摘 要:很多同学都在问IIf() 函数的意义,在这可以了解一下。
正 文:
IIf 函数
根据PNG的求值,返回两部分之一。
在任何可以使用表达式的位置均可使用 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, "大", "小") 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([发货日期]=Date(),"今天发货","未发货"))
适用于: Access 2013, Access 2007, Access 2010
Access软件网官方交流QQ群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- Access对子窗体数据进行批...(10.30)
- 最精简的组合框行来源数据快速输...(10.25)
- Access仿平台的多值选择器...(10.24)
- 【Access日期区间段查询】...(10.22)
- 【Access源码示例】VBA...(10.12)
- Access累乘示例,Acce...(10.09)
- 数值8.88,把整数8去掉,转...(10.08)
- 【Access自定义函数】一个...(09.30)
- 【Access选项卡示例】Ac...(09.09)
学习心得
最新文章
- Access快速开发平台--使用组...(11.25)
- Access快速开发平台--对上传...(11.22)
- Access快速开发平台企业版--...(11.18)
- 不会用多表联合查询,多表查询没结果...(11.16)
- 【案例分享】主键字段值含有不间断空...(11.16)
- Access快速开发平台--后台D...(11.14)
- 微软Access邀测新Monaco...(11.12)
- Access列表框左右互选、列表框...(11.11)
- 高效率在导入数据前删除记录(11.10)
- Access报价单转订单示例代码(11.08)