网站首页 > 知识剖析 正文
本文于2023年4月18日首发于本人同名公众号:Excel活学活用,更多文章敬请关注!
前面我们分享了使用ListVeiw进行数据展示(Excel VBA 数据分析展示/ListView控件),今天在继续完成科目汇总的功能,但由于代码搞得有点复杂,感觉自己给自己挖了个坑,看看时间,今天可能是完不成了,等做好了再跟大家分享吧,今天就来点简单的,分享两个自定义函数,在后面会用到:
一、数组字段定位:在一个一维数组,或2维数组的首行、首列,取得一个字段的位置,省去我们扳手指头的麻烦:
Function Pxy(arr(), FieldName As String, Optional arrType As Integer = 0)
k = 0
t = 0
Select Case arrType
Case Is = 0
For i = LBound(arr) To UBound(arr)
k = k + 1
If arr(i) = FieldName Then
t = 1
Exit For
End If
Next
Case Is = 1
For i = LBound(arr, 1) To UBound(arr, 1)
k = k + 1
If arr(i, 1) = FieldName Then
t = 1
Exit For
End If
Next
Case Is = 2
For i = LBound(arr, 2) To UBound(arr, 2)
k = k + 1
If arr(1, i) = FieldName Then
t = 1
Exit For
End If
Next
End Select
If t = 1 Then
Pxy = k
Else
Pxy = 0
End If
End Function
arr(),就是要定位字段的数组
FieldName,就是要定位的字段名
arrType,定位方式,跟数组的类型有关,默认为0,针对一维数组,1表示二维数组按行定位,2表示二维数组按列定位。
通过循环,如果找到了匹配的字段,则退出循环,使得t=1,表示找到了,函数的值就是当前k的值,如果最后t的值为0,则表示没有找到,函数的值为0。
我们就可以这样用:arrSelect(j, Pxy(TbTitle, "借方发生额", 2)) ,表示在数组arrSelect的第j行,"借方发生额"那一列的值。
这里要注意数组的下标如果是从0开始,那么pxy函数的值要减去1,才能正确引用。
二、数组字段排序:把一个一维数组按升序排列,在我们做科目汇总表的时候,科目要按顺序排列。
Sub SortArray(ByRef arr() As Variant)
Dim temp As Variant
For i = LBound(arr) To UBound(arr)
For j = i + 1 To UBound(arr)
If arr(j) < arr(i) Then
temp = arr(i)
arr(i) = arr(j)
arr(j) = temp
End If
Next
Next
End Sub
我们在做科目汇总表的时候,采用字典的方法把明细账中出现的科目列出来,但顺序是科目在明细账中首次出现的顺序,这样显然是不行的,所以要排个序。
好了,今天就分享这么多,琢磨代码去喽,我们下期再会。
☆猜你喜欢☆
Excel VBA 这样酷炫的日期控件,你不想要吗?
Excel VBA 最简单的收发存登记系统
Excel 公式函数/数据验证/动态下拉列表
Excel VBA 文件批量改名
Excel 公式函数/数据透视表/固定资产折旧计提表!
Excel VBA 输入逐步提示/TextBox+ListBox
本文于2023年4月18日首发于本人同名公众号:Excel活学活用,更多文章敬请关注!
猜你喜欢
- 2025-01-20 Excel中的6个经典排序技巧都不掌握,还敢称Excel达人?
- 2025-01-20 查询函数Choose、Lookup、Hlookup、Vlookup应用技巧解读
- 2025-01-20 一起学《C程序设计》第六课——数组、字符串及实战练习
- 2025-01-20 一文解决CSP-J考纲所有排序算法
- 2025-01-20 java基础,arrays类,Java的八种排序,冒泡排序
- 2025-01-20 excel中什么是数组,数组的作用是什么,这篇文章就带你入门
- 2025-01-20 16.9 数组 - 数据排序技术
- 2025-01-20 怎么求第K大的数,topK 问题(快排的应用)java
- 2025-01-20 VBA按日期统计就餐时段刷卡及人数(数组字典内置函数去重排序)
- 2025-01-20 JS 判断两个数组是否相等,元素以及顺序相等,顺序不同但元素相等
- 04-29php开发者composer使用看这一篇就够了
- 04-29引用和变量声明在不同语言中的实作
- 04-29PHP 没你想的那么差
- 04-29Ubuntu linux 上的 Nginx 和 Php 安装
- 04-29CentOS下通过yum搭建lnmp(单版本PHP)
- 04-29为什么 PHP8 是个高性能版本
- 04-29PHP8函数包含文件-PHP8知识详解
- 04-29使用无参数函数进行命令执行
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)