ExcelTip.Net留存知识帖 ---【注:附件之前被网盘供应商清空后,现已修复-现已修复-现已修复为本地下载!】
现在位置:首页 > E问E答 > Excel VBA > 如何用vba代码获取科目最末级代码?

如何用vba代码获取科目最末级代码?

作者:绿色风 分类: 时间:2022-08-17 浏览:94
楼主
kevinchengcw
Q: 如何用vba代码获取科目最末级代码?
A: 代码如下:
  1. Sub test()
  2. Dim Dic As Object, Arr, I%, N&, Str$
  3. I = 4  '定义最初级科目代码长度,方便修改程序
  4. Arr = Range("a2:a" & Cells(Rows.Count, 1).End(3).Row).Formula  '将科目列表数据放入数组
  5. Set Dic = CreateObject("scripting.dictionary")  '创建字典项目
  6. For N = LBound(Arr) To UBound(Arr)  '循环科目列表数据各项
  7.     If Trim(Arr(N, 1)) <> "" Then  '如果数据有效,则
  8.         Str = Left(Arr(N, 1), I)  '截取最初级段赋值给变量
  9.         If Dic.exists(Str) Then  '如果字典已存在该项目,则
  10.             If Len(Arr(N, 1)) > Dic(Str) Then Dic(Str) = Len(Arr(N, 1))  '如果当前科目代码长度超过已有记录,则更新长度记录
  11.         Else    '否则将当前项目添加到字典中
  12.             Dic.Add Str, Len(Arr(N, 1))
  13.         End If
  14.     End If
  15. Next N
  16. For N = LBound(Arr) To UBound(Arr)  '再循环一次数据区,将科目中不是最末级长度的代码全部清空
  17.     If Trim(Arr(N, 1)) <> "" Then
  18.         Str = Left(Arr(N, 1), I)
  19.         If Len(Arr(N, 1)) < Dic(Str) Then Arr(N, 1) = ""
  20.     End If
  21. Next N
  22. With [e2].Resize(UBound(Arr))  '设定输出区域
  23.     .NumberFormatLocal = "@"  '设定单元格格式为文本
  24.     .Value = Arr  '输出结果
  25. End With
  26. Set Dic = Nothing  '清空字典项目
  27. End Sub

详见附件及素材源帖.
Demo.rar
2楼
xyf2210
学习

免责声明

有感于原ExcelTip.Net留存知识的价值及部分知识具有的时间限定性因素, 经与ExcelTip.Net站长Apolloh商议并征得其同意, 现将原属ExcelTip.Net的知识帖采集资料于本站点进行展示, 供有需要的人士查询使用,也慰缅曾经的论坛时代。 所示各个帖子的原作者如对版权有异议, 可与本人沟通提出,或于本站点留言,我们会尽快处理。 在此,感谢ExcelTip.Net站长Apolloh的支持,感谢本站点所有人**绿色风(QQ:79664738)**的支持与奉献,特此鸣谢!
------本人网名**KevinChengCW(QQ:1210618015)**原ExcelTip.Net总版主之一

评论列表
sitemap