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

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

在VBA(Visual Basic for Applications)中,CHOOSE 函数允许你根据索引从一个列表中选择一个值。如果你想重写这个函数并使用数组来实现相同的功能,你可以创建一个自定义的VBA函数。下面是一个简单的例子:

基础概念

CHOOSE 函数的基本语法是:

代码语言:txt
复制
CHOOSE(index_num, value1, [value2], ...)

其中 index_num 是一个数字,用于指定你想要返回的值的位置,value1, value2, ... 是一系列可能的值。

自定义VBA函数

你可以创建一个自定义函数 MyChoose,它接受一个索引和一个数组作为参数,并返回数组中相应索引的值。

代码语言:txt
复制
Function MyChoose(index_num As Integer, arr() As Variant) As Variant
    ' 检查索引是否在数组范围内
    If index_num >= LBound(arr) And index_num <= UBound(arr) Then
        MyChoose = arr(index_num)
    Else
        ' 如果索引超出范围,可以选择抛出错误或返回空值
        MyChoose = CVErr(xlErrValue) ' 返回 #VALUE! 错误
    End If
End Function

优势

  1. 灵活性:自定义函数可以根据你的具体需求进行调整。
  2. 性能:对于大量数据操作,自定义函数可能比内置函数执行得更快。
  3. 可读性:自定义函数可以提高代码的可读性和可维护性。

类型

在这个例子中,MyChoose 函数是一个简单的数组查找函数。

应用场景

  • 当你需要根据索引从一个列表中选择值时。
  • 当你需要在VBA脚本中重复使用相同的逻辑时。
  • 当你需要对选择过程进行额外的控制或验证时。

遇到问题及解决方法

如果你在使用这个自定义函数时遇到了问题,比如返回了错误的结果或运行时错误,你可以检查以下几点:

  1. 索引范围:确保传递给函数的索引值在数组的有效范围内。
  2. 数组声明:确保数组已经被正确声明并且填充了数据。
  3. 错误处理:如果索引超出范围,函数会返回 #VALUE! 错误。你可以根据需要修改这部分逻辑,比如返回一个默认值或抛出一个自定义错误。

示例代码

下面是如何在VBA中使用 MyChoose 函数的一个例子:

代码语言:txt
复制
Sub TestMyChoose()
    Dim myArray() As Variant
    myArray = Array("Apple", "Banana", "Cherry", "Date")
    
    Dim index As Integer
    index = 2 ' 我们想要获取数组中的第三个元素
    
    Dim result As Variant
    result = MyChoose(index, myArray)
    
    ' 输出结果
    Debug.Print "The selected fruit is: " & result
End Sub

在这个例子中,TestMyChoose 子程序会输出 "The selected fruit is: Cherry",因为索引 2 对应于数组中的 "Cherry"。

请注意,VBA中的数组索引是从0开始的,所以索引 2 实际上是数组中的第三个元素。

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

相关·内容

在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 下面是一个如何处理包含数字的字符串排序的小演示(可以使用自动筛选来查看默认排序与排序代码的结果对比

90110

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

    使用VBA在PowerPoint中创建倒计时器

    标签: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.4K21

    『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

    在PHP中strpos函数的正确使用方式

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

    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

    使用functools.singledispatch在Python中实现函数重载

    对于 Python 这门动态类型语言来说,传统上函数参数是不指定类型的,函数重载也就无从谈起。在 Python 中要实现根据不同参数类型来执行不同的逻辑,一般要使用条件判断。...使用functools.singledispatch实现函数重载 事实上针对根据不同类型参数执行不同逻辑的场景,在 Python 中可以使用functools.singledispatch来实现一定程度的函数重载...使用类型注解 在上面的示例中,重载函数的类型是作为参数传到register方法中的,随着 Python 类型注解机制的成熟和广泛使用,在 Python3.7 及以上的版本我们可以直接使用类型注解来定义重载函数的参数类型...在处理不同事件时,传统模式可能会使用大量的分支判断,使用functools.singledispatch可以简化事件的处理流程。 我们可以先定义基本的事件类和事件处理函数。...,在代码中合理利用functools.singledispatch可以有效地简化代码,提高代码的可读性和可维护性。

    2.1K20

    转换符说明使用方法(在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 和浮点型转换说明一起使用,表示

    22930

    使用VBA在PowerPoint中创建倒计时器(续)附示例PPT下载

    接上篇:使用VBA在PowerPoint中创建倒计时器 标签:VBA,PowerPoint编程 看看倒计时器的VBA代码: Dim time As Date time = Now() Dim count...注意,DateAdd函数中“s”是添加的时间的单位;count是加多少时间;time是时间基数。也就是说,给time添加30秒。当然,如果想添加30分钟,则将“s”修改为“n”。...这可以在Do Loop循环中添加一个if-then条件。当然,也可以在倒计时结束时将演示重定向到某个幻灯片或播放声音效果,而不是使用消息框。...可以使用DateDiff函数来解决,使倒计时器从120开始,到0结束。...同样,也可以使用VBA代码在PowerPoint中制作显示增加的时间的“计时器”。

    1.9K41
    领券