UDF.dll包含了一组实用的用户自定义函数,提供了数组处理的快速方法,可以在VB6、VBS、32位VBA中调用。

看完如下的实例代码,就明白它的用处了。

Private MyUDF As New UDF.ArrayConversion
Sub 是否包含某元素()
Dim Array1( To ) As String
Array1() = "Word"
Array1() = "Excel"
Array1() = "Outlook"
Array1() = "Access"
Debug.Print MyUDF.Contains(Array1, "Excel") '打印结果为True
End Sub
Sub 倒序()
Dim Array1( To ) As String
Array1() = "Word"
Array1() = "Excel"
Array1() = "Outlook"
Array1() = "Access"
Dim Array2 As Variant
Array2 = MyUDF.Reverse(Array1) '倒序的结果返回给Array2
Debug.Print Join(Array2, "/") '打印结果为Access/Outlook/Excel/Word
MyUDF.ReverseSelf Array1 '直接对Array1进行倒序
Debug.Print Join(Array1, "/") '打印结果为Access/Outlook/Excel/Word
End Sub
Sub 去重()
Dim Array1( To ) As Integer
Array1() =
Array1() =
Array1() =
Array1() =
Array1() =
Dim Array2 As Variant
Array2 = MyUDF.Distinct(Array1)
Debug.Print Join(Array2, "/") '打印结果为22/33/44
End Sub
Sub 连接数组()
Dim Array1( To ) As String
Array1() = "Word"
Array1() = "Excel"
Array1() = "Outlook"
Array1() = "Access"
Dim Array2 As Variant
Array2 = MyUDF.JoinArray(Array1, Array(, , ), Array(True, False))
Debug.Print Join(Array2, "/") '打印结果为Word/Excel/Outlook/Access/1/2/3/True/False
End Sub
Sub 排序()
Dim Array1( To ) As String
Array1() = "Word"
Array1() = "Excel"
Array1() = "Outlook"
Array1() = "Access"
Dim Array2 As Variant
Array2 = MyUDF.Sort(Array1)
Debug.Print Join(Array2, "/") '打印结果为Access/Excel/Outlook/Word
MyUDF.SortSelf Array1 '对Array1自身升序
MyUDF.ReverseSelf Array1 '对Array1自身倒序
Debug.Print Join(Array1, "/") '打印结果为Word/Outlook/Excel/Access
End Sub
Sub 检索元素位置()
Dim Array1( To ) As String
Array1() = "Word"
Array1() = "Excel"
Array1() = "Outlook"
Array1() = "Access"
Array1() = "Excel"
Debug.Print MyUDF.IndexOf(Array1, "Outlook") '结果:4
Debug.Print MyUDF.IndexOf(Array1, "outlook") '结果:-1
Debug.Print MyUDF.LastIndexOf(Array1, "Excel") '结果:6
End Sub
Sub 指定位置插入另一数组()
Dim A( To ) As Integer
A() =
A() =
A() =
A() =
A() =
Dim B(- To -) As String
B(-) = "Word"
B(-) = "Excel"
B(-) = "Outlook"
Dim Array3 As Variant
Array3 = MyUDF.InsertRange(A, , B)
Debug.Print Join(Array3, "/") '打印结果为22/33/Word/Excel/Outlook/22/44/33
End Sub
Sub 删除连续多个元素()
Dim Array1( To ) As String
Array1() = "Word"
Array1() = "Excel"
Array1() = "Outlook"
Array1() = "Access"
Array1() = "Excel"
Dim Array2 As Variant
Array2 = MyUDF.RemoveRange(Array1, , )
Debug.Print Join(Array2, "/") '打印结果为Word/Access/Excel
End Sub
Sub 部分元素构成新数组()
Dim Array1( To ) As String
Array1() = "Word"
Array1() = "Excel"
Array1() = "Outlook"
Array1() = "Access"
Array1() = "Excel"
Dim Array2 As Variant
Array2 = MyUDF.GetRange(Array1, , )
Debug.Print Join(Array2, "/") '打印结果为Excel/Outlook/Access
End Sub
Sub 用另一数组覆盖一部分元素()
Dim Array1( To ) As Integer
Array1() =
Array1() =
Array1() =
Array1() =
Array1() =
Dim Array2() As String
Array2() = "Word"
Array2() = "Excel"
Array2() = "Outlook"
Dim Array3 As Variant
Array3 = MyUDF.SetRange(Array1, , Array2)
Debug.Print Join(Array3, "/") '打印结果为2/Word/Excel/Outlook/6
End Sub

下载地址:UDF.zip

下载后解压缩,根据 使用说明.txt 中的内容执行操作。

注册成功后,可以在VBA添加如下引用:

2019/6/28 新增一个求和函数,可以对任意形式的数组进行数值求和,即使嵌套的数组也可以逐层求出。用法如下:

除了下面列出的实例外,大家如果有其他类型的求和,也可以用该函数试试。

Sub 对多个参数直接求和()
'参数个数不限
Total = MyUDF.Sum(1, 2, 3, "Test", 4)
Debug.Print Total '返回10
End Sub
Sub 对任意数组求和()
Dim AnyArray As Variant
AnyArray = Array(-1, -2, Array(3, 4, 5), 6)
Debug.Print MyUDF.Sum(AnyArray) '返回15
End Sub
Sub 对多个数组求和()
Dim A(1 To 2) As Integer
Dim B(1 To 3) As Single
A(1) = 1: A(2) = 2
B(1) = 1: B(2) = 2: B(3) = 3
Debug.Print MyUDF.Sum(A, B) '返回9
End Sub

面向VBA一维数组的实用自定义函数的更多相关文章

  1. 题目要求:传入数组 内容为[['lisi','男','27'],['wangwu','男',18],['zhaoliu','男','30']],将此二维数组转化为一维数组,创建自定义函数完成

    //自定义函数 function getOne($arr){ $str = ''; //定义空的字符串,用来接收值 foreach ($arr as $key=>$value){ //循环遍历数 ...

  2. VBA 定义能返回数组公式的自定义函数

    返回一个变量大小结果数组的方法 此方法返回基于一个参数范围的值的数组.结果数组的大小具体取决于参数数组中的元素数量波动.例如对于假定您要创建一个范围中的每个值乘以 100 的函数.下面的自定义函数接受 ...

  3. GDAL中RasterIO函数(把文件读取为一个一维数组)和ReadBlock函数(读取栅格数据块)

    CPLErr GDALRasterBand::RasterIO ( GDALRWFlag eRWFlag, int nXOff, int nYOff, int nXSize, int nYSize, ...

  4. numpy基础教程--将二维数组转换为一维数组

    1.导入相应的包,本系列教程所有的np指的都是numpy这个包 1 # coding = utf-8 2 import numpy as np 3 import random 2.将二维数组转换为一维 ...

  5. PHP实用系统函数之数组篇

    PHP中十分实用的系统函数 array array_merge 说明:array  array_merge ( array $array1 [, array $... ] ) 将一个或多个数组的单元合 ...

  6. VBA Excel 常用 自定义函数

    1. 将 互换 Excel 列号(数字/字母) Public Function excelColumn_numLetter_interchange(numOrLetter) As String Dim ...

  7. PHP如何判断一个数组是一维数组或者是二维数组?用什么函数?

    如题:如何判断一个数组是一维数组或者是二维数组?用什么函数? 判断数量即可 <?php if (count($array) == count($array, 1)) { echo '是一维数组' ...

  8. Excel VBA自定义函数编写(UDF, User-Defined Function)

    虽然知道Microsoft Office Excel可以支持用VB语言来进行复杂的编程和自定义函数的编写,但是一直以来都没有这个需求. 这次遇到的问题是要根据一列数组计算出一个值,但计算过程又比较复杂 ...

  9. [VBA]用一个简单例子说明如何在Excel中自定义函数

    Excel中的函数无疑是强大的,但是再强大的战士也有他脆弱的脚后跟[1].这两天在使用Excel的时候遇到了一个需求,要在某一个单元格里面自动计算今天是星期几(如显示 Today is Tuesday ...

随机推荐

  1. 如何搞定Critical Thinking写作?

    受中国传统教育模式与国外一流大学之间的差异的影响,在海外留学的学子们常常会在新的学习生活中面临许多难题,Critical Thinking就是其中之一.国内的教育方法常常以灌输式的教育模式为主,忽略了 ...

  2. MyBatis:一对多、多对一处理

    多对一的处理 多对一的理解: 多个学生对应一个老师 如果对于学生这边,就是一个多对一的现象,即从学生这边关联一个老师! 数据库设计 CREATE TABLE `teacher` ( `id` INT( ...

  3. PAT A1015-1016

    A 1015 Reversible Primes 看清题意即可.给的数是十进制的,需要先判断是不是素数,然后按照给定进制转化成字符串后进行翻转,最后再转化为十进制并判断是否为素数. #include ...

  4. HTTP协议(三):状态码

    前言 作者说:在上一节的内容中,HTTP大佬介绍了他是怎么让服务器和用户达成信息交互的,详细的说明了连接建立过程中用到的一些基本的技术原理,包括请求报文响应报文.建立持久化连接用的Cookie技术等内 ...

  5. 基于python的爬虫流程图(精简版)

    网址: https://www.processon.com/view/link/5e1148b8e4b07db4cfa9cf34 如果链接失效,请及时反馈(在评论区评论),博主会及时更新

  6. Mac OS/Windows好用软件分享

    下软件全部为破解版,仅供参考学习用,如涉及商业. 请支持正版!谢谢 全部为本人亲测过 看上哪个留言发给你!   直接全分享上来会有人居心不良!

  7. zabbix中文乱码解决

    问题现象: zabbix字体修改成中文后监控显示乱码 原因: 该问题是由于zabbix默认使用的是“DejaVuSans.ttf”(zabbix3.2.7默认使用的是“graphfont.ttf”), ...

  8. H3C S10512虚拟化配置

    软件版本:Version 7.1.070, Release 7585P05 1.配置SW1#设置SW1的成员编号为1,创建IRF端口2,并将它与物理接口Ten-G0/0/45.Ten-G0/0/46. ...

  9. centos挂载磁盘

    Aliyun实例为例 简单操作: 查看磁盘情况:fdisk -l 对数据盘进行分区,一般类似/dev/vdb这种为数据盘 输入fdisk  /dev/vdb 对数据盘进行分区.根据提示,输入 n, p ...

  10. 86.QuerySet API常用的方法详解:get方法

    get方法的查询条件只能有一条数据满足,如果匹配到多条数据都满足,就会报错:如果没有匹配到满足条件的数据,也会报错. 示例代码如下: from django.http import HttpRespo ...