- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
考虑一个具有多个可选参数的函数。例如:
Function foo(Optional a, Optional b, Optional c, Optional d)
如果我只想在参数不为空的情况下调用特定函数,或进行其他测试(因为该函数会引发错误,除非参数丢失)。
Collection 类就是一个例子。 Add 方法有 3 个可选参数。许多自定义类包装此类 - 例如创建“Person”自定义类的可索引类 Persons 或类似的类。包装器必须处理 6 种组合:仅添加 Key、添加 Key 并指定 Before、添加 Key 并指定 After、不添加 Key 并指定 Before、不添加 Key 并指定 After、无 Key 且无 Before/后。如果将包装器编写为具有十几个可选参数的 Workbook.Save 之类的东西,情况会变得更糟。
我不知道有什么办法可以替代一些乏味的结构,例如:
If a <> Null Then
If b <> Null Then
If c <> Null Then
If d <> Null Then
foo a, b, c, d
Else
foo a, b, c
End If
Else
If d <> Null Then
foo a, b, d
Else
foo a, b
End If
End If
Else
'... Etc ...
显然,对于每个附加的可选变量,嵌套 If 的数量和一般代码开销大约会增加一倍。
在 .NET 中,可以传入 System.Type.Missing 类型,从而使表达式变得更加简单。
就像在 C# 中一样,它可以像以下一样干净:
foo(a ?? Missing, b ?? Missing, c ?? Missing, d ?? Missing);
(这表示“如果 a 为 null,则传入 Missing (或者可能在幕后重构调用本身),调用相当于不为可选参数 a 传递任何内容,等等)
如果实现了,则可以在 VBA 中使用内联 iff ('IIF(boolean, true, false)') 进行等效操作
是否有我缺少的 VBA 解决方法?
最佳答案
(编辑时:我合并了 HarveyFrench 对代码的改进)
您可以减少嵌套:
Function foo(Optional a, Optional b, Optional c, Optional d)
Dim passed As String
If Not IsMissing(a) Then passed = "a "
If Not IsMissing(b) Then passed = passed & "b "
If Not IsMissing(c) Then passed = passed & "c "
If Not IsMissing(d) Then passed = passed & "d "
foo = IIf(Len(passed) = 0, "Nothing ", passed) & "passed"
End Function
Function foo_dispatcher(Optional a, Optional b, Optional c, Optional d)
Dim caseNum As Long
caseNum = IIf(IsNull(a) Or IsEmpty(a) Or IsMissing(a), 0, 8)
caseNum = caseNum + IIf(IsNull(b) Or IsEmpty(b) Or IsMissing(b), 0, 4)
caseNum = caseNum + IIf(IsNull(c) Or IsEmpty(c) Or IsMissing(c), 0, 2)
caseNum = caseNum + IIf(IsNull(d) Or IsEmpty(d) Or IsMissing(d), 0, 1)
Select Case caseNum
Case 0: foo_dispatcher = foo()
Case 1: foo_dispatcher = foo(, , , d)
Case 2: foo_dispatcher = foo(, , c)
Case 3: foo_dispatcher = foo(, , c, d)
Case 4: foo_dispatcher = foo(, b)
Case 5: foo_dispatcher = foo(, b, , d)
Case 6: foo_dispatcher = foo(, b, c)
Case 7: foo_dispatcher = foo(, b, c, d)
Case 8: foo_dispatcher = foo(a)
Case 9: foo_dispatcher = foo(a, , , d)
Case 10: foo_dispatcher = foo(a, , c)
Case 11: foo_dispatcher = foo(a, , c, d)
Case 12: foo_dispatcher = foo(a, b)
Case 13: foo_dispatcher = foo(a, b, , d)
Case 14: foo_dispatcher = foo(a, b, c)
Case 15: foo_dispatcher = foo(a, b, c, d)
End Select
End Function
Sub test()
Debug.Print foo_dispatcher(Null, Null, Null, Null)
Debug.Print foo_dispatcher(Null, 1, Null, 2)
Debug.Print foo_dispatcher(1, 2, 3, 4)
Debug.Print foo_dispatcher()
Debug.Print foo_dispatcher(, 1, , 2)
Debug.Print foo_dispatcher(a:=1, d:=Null)
End Sub
测试
的输出:
Nothing passed
b d passed
a b c d passed
Nothing passed
b d passed
a passed
显然,这 16 种情况中的操作可以根据 foo
的调用约定进行定制(例如,您可以分派(dispatch)到 foo(a,d)
而不是 foo(a,,,d)
如果你需要的话)。我没有明确检查所有 16 个案例,但它似乎有效。我所做的有点机械。您可以编写一个调度生成器 - 一个函数,它接受字符串函数名称、必需参数数组、可选参数数组以及充当 Null
角色的值并返回调度程序作为一个字符串,可以从直接窗口复制粘贴到代码模块。我想过在这里这样做,但对于概念验证调度程序来说似乎不值得。
关于VBA - 有条件地调用具有某些可选参数的函数的解决方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31808340/
如何在 2014-10-04 - 2014-10-30 仅工作日和 08.00 - 20.00 之间随机更新日期列? 2014-10-04 - 2014-10-30 random working-da
我有一个二维 (3x7) 数组,我想转换为一维数组,以便我提供的行位于中心。行值可能沿途变化,但必须位于中心。 #define numRows 3 #define numCols 7 #define
我有2张 table : 第一个是“人”: person_id, 人名 第二个是“PersonsGraphs”: person_id1, person_id2, 关系类型 我正在寻找一种建立“家谱”的
是否可以在序列化 JSON 响应的同时根据 If 条件排除某些元素? if(a == 1) { //show element } else { //don't show element }
是否可以在序列化 JSON 响应的同时根据 If 条件排除某些元素? if(a == 1) { //show element } else { //don't show element }
尝试使用 jQuery 编写一个条件,该条件基本上说明,如果 div.gathering 不包含 a.cat-link,则执行以下操作。我已经尝试过以下方法,但似乎不起作用。有人能解释一下吗? if(
该练习要求插入值 x 的副本(这也是要在列表中搜索的值),但前提是该位置是另一个值 n 的倍数。未指定副本应插入到 x 值之前还是之后。 我的问题是并非在所有情况下都插入副本。我认为问题在于,当我插入
我遇到了这个[问题]:How can I store values into a multi-parameter struct and pass typedef struct to a functio
出于某种原因,当我编写 getWinner() 时,它仅适用于 2 种情况(最后一行)。就对角线和列而言,我拥有其他一切,但第 2 行(嗯,三,但数组,所以 2)基本上只适用于 o。只有当 o 位于
我有一个问题。 我想将“guid”列中的值复制到“帖子内容” 所有行都在一个表“wp-posts”中 “postparent”列中的一行有一个值,而“ID”列中的另一项也有相同的值 我必须做的事情是
我想将两个像这样的表合并到一个表中,并为重复的键行添加合并表中最旧的 DateAdded 值。 (Key1,Key2) 是主键。 +-----------+-----------+------+---
通过下面的表格和数据,我试图获得最高的 effective_from每个唯一 brand 小于当前时间戳的值/model组合 - 实际上是每件商品的当前价格。 CREATE TABLE things
您能告诉我如何删除未知号码的最后一条记录(有条件)吗? 例如,在这种情况下我想删除id为6到10的记录。 注意:该表和记录不是恒定的。 +----+-----+---------+ | id | ur
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
我有两个表, 标签 -> id,name,description,user,status 标签_连接。 -> id, Label_id, 类别 所以有多个类别,假设 1 => 新的,2 => 旧的。
好的,我会长话短说。 这是我的代码 String s = edittextkata.getText().toString(); String[] vowels = {"a","
我有一个非常具体的要求,我发现很难做到,我需要查找并替换文件中的某些行,但问题是文本不同,唯一的好处是它们都有一个 .[扩展名] 例如: 30/07/2012 14:46 17
我有一个大型数据库,其中存在各种不一致之处。我想澄清的项目之一是根据人口更改国家/地区状态。 数据样本是: { "_id" : "D", "name" : "Deutschland", "pop" :
我需要将范围(有条件)中的唯一值组合到同一行的另一个范围中。 其实我前两天发过类似的问题Link所提供的答案在我提出上述问题时有效。 但后来,我遇到了一个新问题,我宁愿问一个新的问题,让它更清楚: (
我刚开始使用 VBA,并且正在努力处理需要清理的工作表。 我有一列包含混合邮政编码和城市名称的字符串。我想从 A 列中提取邮政编码并放在 B 列中,并在 C 列中提取带有下划线的城市名称。 我的(示例
我是一名优秀的程序员,十分优秀!