首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在VBA中重写CHOOSE函数(使用数组)

在VBA中,可以通过使用数组来重写CHOOSE函数。CHOOSE函数是一个非常有用的函数,它允许根据给定的索引值从一组值中选择一个值。但是,CHOOSE函数的参数是固定的,不能动态地根据需要进行扩展或修改。通过使用数组,我们可以实现更灵活和可扩展的选择功能。

首先,我们需要定义一个数组来存储要选择的值。数组可以包含任意数量的元素,每个元素都代表一个可选的值。例如,我们可以定义一个名为"choices"的数组,并将要选择的值存储在其中:

代码语言:txt
复制
Dim choices(1 To 3) As Variant
choices(1) = "Option 1"
choices(2) = "Option 2"
choices(3) = "Option 3"

接下来,我们可以编写一个函数来实现选择功能。该函数接受一个索引值作为参数,并返回对应的值。函数可以使用索引值来访问数组中的元素,并返回该元素的值。例如,我们可以编写一个名为"ChooseValue"的函数:

代码语言:txt
复制
Function ChooseValue(index As Integer) As Variant
    Dim choices(1 To 3) As Variant
    choices(1) = "Option 1"
    choices(2) = "Option 2"
    choices(3) = "Option 3"
    
    If index >= 1 And index <= 3 Then
        ChooseValue = choices(index)
    Else
        ChooseValue = "Invalid index"
    End If
End Function

在这个函数中,我们首先检查索引值是否在有效范围内。如果是,则返回对应的值;如果不是,则返回一个错误消息。

使用这个重写的CHOOSE函数非常简单。只需要调用"ChooseValue"函数,并传入要选择的索引值作为参数。例如,要选择第二个值,可以使用以下代码:

代码语言:txt
复制
Dim selectedValue As Variant
selectedValue = ChooseValue(2)

以上代码将返回"Option 2"作为选择的值,并将其存储在"selectedValue"变量中。

这种重写的CHOOSE函数在许多情况下都非常有用,特别是当需要根据动态条件进行选择时。它可以灵活地适应不同的需求,并且可以轻松地扩展和修改选择的值。

腾讯云相关产品和产品介绍链接地址:

请注意,以上链接仅供参考,具体产品和服务选择应根据实际需求进行评估和决策。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

VBA数组排序的代码

标签:VBA 这是一段非常好的代码,来自ozgrid.com,可以使用它来快速排序VBA数组。 代码如下: '对一维或二维数组排序....'二维数组可以通过传递适当的列编号作为sortKeys参数来指定其排序键. '函数传递一个引用,因此将对原始数组进行变异....'如果不需要,必须传递一份副本. ' '示例使用: ' sortArray myArray - 一维数组 ' sortArray myArray, 2...- 二维数组, 单个排序键 ' sortArray myArray, Array(2,3,1) - 二维数组,多个排序键 Function sortArray(ByRef arr As Variant...arr1 Erase arr2 Erase tmp On Error GoTo 0 sortArray = arr End Function 下面是一个如何处理包含数字的字符串排序的小演示(可以使用自动筛选来查看默认排序与排序代码的结果对比

84010

VBA:获取指定数值指定一维数组的位置

文章背景:采用VBA抓取数据时,有时需要判断指定数值是否一维数组已存在;如果存在,则希望能够获取该数值在数组内的位置。...实践过程中发现,VBA的filter函数无法完全匹配指定数值;而借助Excel的match函数,可以实现完全匹配。接下来分别对Filter函数和Match函数进行介绍。...指出要使用的字串比较种类的数值。 compare引数可具有以下的值: vbBinaryCompare选项,区分大小写;vbTextCompare选项,不区分大小写。...应用示例: 判断某字符串是否一维数组内存在。 由上图可以看出,采用Filter函数匹配到的是包含A-1的所有元素。而在实际案例,可能希望只获得完全匹配的元素。...WorksheetFunction.Match 方法 傳回項目陣列的相對位置,其符合指定順序的指定值。

7.3K30
  • 使用insert () MongoDB插入数组

    “insert”命令也可以一次将多个文档插入到集合。下面我们操作如何一次插入多个文档。...我们完成如下步骤即可: 1)创建一个名为myEmployee 的JavaScript变量来保存文档数组; 2)将具有字段名称和值的所需文档添加到变量; 3)使用insert命令将文档数组插入集合...如下的例子,我们将使用JSON格式查看输出。 让我们看一个以JSON格式打印的示例 db.Employee.find()。...forEach(printjson) 代码说明: 第一个更改是将对Each()调用的函数附加到find()函数。这样做是为了确保明确浏览集合的每个文档。...这样,您就可以更好地控制集合每个文档的处理方式。 第二个更改是将printjson命令放入forEach语句。这将导致集合的每个文档以JSON格式显示。

    7.6K20

    Excel VBA解读(137): 让使用用户定义函数数组公式更快

    本文主要研究使用用户定义函数数组公式。 有两类数组公式: 单单元格数组公式输入单个单元格,循环遍历其参数(通常是计算的参数)并返回单个结果。...多单元格数组公式输入多个单元格每个单元格中都返回结果。 使用这种功能需要付出代价:因为数组公式正处理很多工作,所以计算速度很慢(特别是单单元格数组公式)。...可以将VBA用户定义函数所花费的时间分成下列组成部分: 调用用户定义函数的开销时间。 用户定义函数获取将要使用的数据的时间。 执行计算的时间。 返回结果的开销时间。...每次的VBA读写调用都有相当大的开销,因此一次读取和写入大块数据通常要快得多。 因此,应该让VBA用户定义函数单个块尽可能多地读取数据并将数据尽可能大地返回到Excel。...小结: 1.许多实际的例子使用多单元格数组的用户定义函数可能是最快的计算方法。 2.将通常的用户定义函数转换成多单元格数组用户定义函数很简单。

    3.4K20

    使用VBAPowerPoint创建倒计时器

    标签:VBA,PowerPoint编程 我们可以借助于PPT来倒计时,如下图1所示。 图1 首先,幻灯片中插入一个矩形形状,用来显示倒计时时间。...ActivePresentation.SlideShowWindow.View.Slide.Shapes("countdown").TextFrame.TextRange = Format((time - Now()), "hh:mm:ss") Loop End Sub 代码,...回到幻灯片,选择矩形形状,单击功能区“插入”选项卡“链接”组的“动作”按钮,如下图2所示。...图2 弹出的“操作设置”对话框,选取“运行宏”单选按钮,在其下拉列表中选择CountDown过程,如下图3所示。 图3 幻灯片中,可以设置矩形的字体及大小,调整矩形位置等。...然后,点击放映幻灯片,矩形单击,即可开始倒计时,正如上图1所示。 接下来,我们介绍实现在PPT显示计时的多种情形下的VBA代码。 未完待续……

    2.2K20

    『Excel进化岛精华曝光』 VBA调用OFFICE365新函数

    VBA虽然整体语言上的更新是停滞的,但在OFFICE对象接口上,还是会有所更新。...例如Excel里的新增的函数Application.WorksheetFunction类下面会有所更新,但不是全都有,也不知道未来会补充多少。 目前笔者大概找了一圈,有以下函数已经支持。...相对来说,VBA数组各大编程语言里,简直是弱爆了,如果能够借助OFFICE365新出的这些函数VBA里数据处理环节用一下,也会省心不少。...最近Excel进化岛参与动态数组公式的讨论热火朝天,产出不少经典案例,让人隔着屏幕都能感受到激情四射。...从官方的示例,能够学习的真的很少,社区的力量才是强大的,当前Excel进化岛,是一个学习OFFICE365新函数和动态数组公式不错的平台,欢迎加入。

    1.7K50

    关于使用MethodHandle子类调用祖父类重写方法的探究

    关于使用MethodHandle子类调用祖父类重写方法的探究 注:这个例子原本出现在周志明先生的《深入理解Java虚拟机》--虚拟机字节码执行引擎章节,介于有读者朋友有疑问,这里基于Java代码层面解释一下...普通的方法调用,这个this参数是虚拟机自动处理的,表示的是当前实例对象,我们方法可以直接使用。...我觉得使用bindTo绑定方法接收者要比invoke方法传递更加友好,也更加符合程序员的大众理解,invoke可以只专注方法显式的入参。 然后再来说bindTo(this)的this。...基于这个事实,我们这时可以直接在GrandFather的thinking方法调用Son类独有的方法,使用反射或者直接类型强制转换为Son就行了。...这就要回到findSpecial方法的第四个class类型的参数,即本例中使用的Father.class。

    9.5K30

    Excel VBA解读(136): 在用户定义函数的变体、引用、数组、计算表达式、标量

    学习Excel技术,关注微信公众号: excelperfect 在前面的几篇文章,我们自定义的函数使用定义为Range的参数来从Excel工作表获取数据,例如: Function VINTERPOLATEB...=VINTERPOLATEB(4.5,{1,3,3.5;4,4,4.5;5,4.5,5},2) 这个公式使用了3行3列的数组常量。 Excel调用函数之前会检测到这些参数不是单元格区域。...赋值给函数的返回值的语句行设置断点,如下图1所示 ?...因此,通用目的的用户自定义函数,希望使用Variant型参数,并且经常需要确定变体的类型以及上限和下限。...小结:通用目的的用户自定义函数,必须使用Variant类型的参数而不是Range类型。可以通过处理变量之前确定变体包含的内容来有效地处理出现的问题。

    2K20

    PHPstrpos函数的正确使用方式

    首先简单介绍下 strpos 函数,strpos 函数是查找某个字符字符串的位置,这里需要明确这个函数的作用,这个函数得到的是位置。 如果存在,返回数字,否则返回的是 false。...而很多时候我们拿这个函数用来判断字符串是否存在某个字符,一些同学使用的姿势是这样的 // 判断‘沈唁志博客’是否存在‘博客’这个词 if (strpos('沈唁志博客', '博客')) {...沈唁志博客’的第 0 个位置;而 0 if 中表示了 false,所以,如果用 strpos 来判断字符串是否存在某个字符时 必须使用===false 必须使用===false 必须使用=...==false 重要的事情说三遍,正确的使用方式如下 // 判断‘沈唁志博客’是否存在‘博客’这个词 if (strpos('沈唁志博客', '博客')===false) { // 如果不存在执行此处代码...原创文章采用CC BY-NC-SA 4.0协议进行许可,转载请注明:转载自:PHPstrpos函数的正确使用方式

    5.2K30

    PHP灵活使用foreach+list处理多维数组

    PHP灵活使用foreach+list处理多维数组 先抛出问题,有时候我们接收到的参数是多维数组,我们需要将他们转成普通的数组,比如: $arr = [ [1, 2, [3, 4]],...但是要注意哦,list拆解键值对形式的Hash数组时要指定键名,并且只有7.1以后的版本才可以使用哦 $arr = [ ["a" => 1, "b" => 2], ["a" => 3,...上述代码第二个写法更简单直观,由此发现我们还可以这样来拆解数组。...并且指定键值了就不用在乎他们的顺序了: ["b" => $b, "a" => $a] = $arr[0]; echo $a, ',', $b, PHP_EOL; 原来list()还有这样的语法糖,果然还是要不断的学习,一直使用却从未深入了解过的方法竟然能有这么多的用处...不多说了,接着研究手册其他好玩的东西去咯!

    3.6K10

    转换符说明使用方法(printf函数

    ---- printf()函数打印数据指令时要与代打印数据的类型相匹配才行。 如%d %c %ld......这些符号叫做转换说明。代表着数据转化成显示的形式。...Of %X 无符号十六进制整数,使用十六进制数OF %% 打印一个百分号 %g(或%G) 浮点数不显示无意义的零“0” 其基本格式如下: printf(格式字符串,待打印1,待打印2,.......)...> int main() { int a=1,b=2; printf("有%d个小洁,%d小洁洁", a,b); return 0; } 打印结果为: 有1个小洁,2个小洁洁 注意:格式字符串的转化说明一定要与后面的打印项一一相匹配...,表示short int/unsigned short int类型的值 hh 和整型转换说明一起使用,表示signed char/unsigned char类型的值 l 和整型转换说明一起使用,表示long...int/unsigned long int类型的值 ll 和整型转换说明一起使用,表示long long int/unsigned long long int类型的值 L 和浮点型转换说明一起使用,表示

    21430
    领券