前面我们分享了使用ListVeiw进行数据展示()excel自定义排序怎么设置,今天在继续完成科目汇总的功能,但由于代码搞得有点复杂,感觉自己给自己挖了个坑

,看看时间,今天可能是完不成了,等做好了再跟大家分享吧,今天就来点简单的,分享两个自定义函数excel自定义排序怎么设置,在后面会用到:
一、数组字段定位:在一个一维数组,或2维数组的首行、首列,取得一个字段的位置,省去我们扳手指头的麻烦:
Function Pxy(arr(), FieldName As String, Optional arrType As Integer = 0)k = 0t = 0Select Case arrTypeCase Is = 0For i = LBound(arr) To UBound(arr)k = k + 1If arr(i) = FieldName Thent = 1Exit ForEnd IfNextCase Is = 1For i = LBound(arr, 1) To UBound(arr, 1)k = k + 1If arr(i, 1) = FieldName Thent = 1Exit ForEnd IfNextCase Is = 2For i = LBound(arr, 2) To UBound(arr, 2)k = k + 1If arr(1, i) = FieldName Thent = 1Exit ForEnd IfNextEnd SelectIf t = 1 ThenPxy = kElsePxy = 0End IfEnd 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 VariantFor i = LBound(arr) To UBound(arr)For j = i + 1 To UBound(arr)If arr(j) < arr(i) Thentemp = arr(i)= arr(j)= tempEnd IfNextNextEnd Sub
我们在做科目汇总表的时候,采用字典的方法把明细账中出现的科目列出来,但顺序是科目在明细账中首次出现的顺序,这样显然是不行的,所以要排个序。
好了,今天就分享这么多,琢磨代码去喽,我们下期再会。
限 时 特 惠: 本站每日持续更新海量各大内部创业教程,一年会员只需98元,全站资源免费下载 点击查看详情
站 长 微 信: muyang-0410
声明:本站所有资源系站长耗费大量精力时间物力长期搜集维护,故仅对会员免费开放,每日手选更新,非烂大街的采集站,开通会员: 点击此处自助开通或者联系站长微信muyang-0410开通




