ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 27171|回复: 36

[原创] 树形结构在excel中的实现及利用

  [复制链接]

TA的精华主题

TA的得分主题

发表于 2014-8-4 20:32 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖已被收录到知识树中,索引项:控件
废话不说,看得懂自然看得懂,看不懂说了也白说:
下面举三例,有心人自己揣摸可也。

附件一:树形节点的构建及递归汇总: 树形节点构建递归汇总.zip (16.27 KB, 下载次数: 3657)

评分

3

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-4 20:33 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
附件2:树形 多级有效性

树形 多级有效性.zip

23.52 KB, 下载次数: 1671

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-4 20:35 | 显示全部楼层
附件3:树形多级汇总表

树形汇总表2.zip

36.69 KB, 下载次数: 1431

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-4 21:11 | 显示全部楼层
二叉递归计算混排数字
大小中文数字,阿拉伯数字任你混写,没有什么不能转。附件如下:

二叉递归计算混排数字.zip

12.62 KB, 下载次数: 962

TA的精华主题

TA的得分主题

发表于 2014-8-5 10:46 | 显示全部楼层
wzsy2_mrf 发表于 2014-8-4 20:33
附件2:树形 多级有效性

谢谢分享,树形 多级有效性 中点击E列时出错(光是调小列距或隐藏不是办法),还是用个容错代码或判断解决掉吧,小BUG

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-5 16:41 | 显示全部楼层
aman1516 发表于 2014-8-5 10:46
谢谢分享,树形 多级有效性 中点击E列时出错(光是调小列距或隐藏不是办法),还是用个容错代码或判断解决 ...

加一点容错代码即可:
  1. Private Sub Worksheet_SelectionChange(ByVal Target As Range)
  2.     Dim str$, k&
  3.     If Target.Cells.count > 1 Then Exit Sub
  4.     If Target.Column > 1 Then
  5.         If Target.Offset(0, -1).Value = "" Then Exit Sub
  6.     End If

  7.     With mt    '树初始化
  8.         .count = 0
  9.         Set .d = Nothing
  10.         Erase .md
  11.     End With

  12.     Call buildTree    '建树
  13.     If Target.Column = 1 Then
  14.         With Target.Validation
  15.             .Delete
  16.             .Add 3, 1, 1, Join(mt.root, ",")
  17.         End With
  18.     End If
  19.     If Target.Column > 1 Then
  20.         With Target.Validation
  21.             .Delete
  22.             str = ""
  23.             For k = 1 To Target.Column
  24.                 str = str & "" & Target.Offset(0, k - Target.Column).Value
  25.             Next
  26.             With mt
  27.                 str = Right(str, Len(str) - 1)
  28.                 If .d.Exists(str) Then
  29.                     str = .md(.d(str)).mParent
  30.                     str = Replace(.md(.d(str)).son, "~#", ",")
  31.                 Else
  32.                     str = ""
  33.                 End If
  34.             End With
  35.             If str <> "" Then .Add 3, 1, 1, str
  36.         End With
  37.     End If
  38. End Sub

复制代码

TA的精华主题

TA的得分主题

发表于 2014-8-6 07:27 | 显示全部楼层
学习了  vba里做数据结构的很少  好的数据结构可以省去很多重复的繁琐工作这个如果理解的话 可以很好应用于多级菜单联动,bom计算等有分级数据结构的情况


TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-6 10:10 | 显示全部楼层
百度不到去谷歌 发表于 2014-8-6 07:27
学习了  vba里做数据结构的很少  好的数据结构可以省去很多重复的繁琐工作这个如果理解的话 可以很好应用于 ...

多谢。 在这里能讨论数据结构的太少了,其实何止数据结构,真正讨论技术的也不多,伸手党倒是遍地都是。
其实我很希望有人指出这个树形结构设计的不足,以我所举几例而论,每例都得有所损益,这似乎是个不足。我实际是想用户这种结构来解决BoM问题,但BoM问题很特殊,多个父部件可以拥有同一子部件,如何区分是个难题,做到了区分如何提高设计效率也是问题,总不能同一子部件出现一次就重算一次吧?

TA的精华主题

TA的得分主题

发表于 2014-8-6 10:26 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 百度不到去谷歌 于 2014-8-6 11:00 编辑
wzsy2_mrf 发表于 2014-8-6 10:10
多谢。 在这里能讨论数据结构的太少了,其实何止数据结构,真正讨论技术的也不多,伸手党倒是遍地都是。
...

我最近做代码助手 用了目录树 他那个就是典型的树结构的
我想稍后做一个类 结构类似与目录树控件
将里面加入方法
比如载入数组生成树 从树生成数组等
更新单个节点 导出单个节点
输入输出单元格区域 生成菜单 ==

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-6 11:43 | 显示全部楼层
百度不到去谷歌 发表于 2014-8-6 10:26
我最近做代码助手 用了目录树 他那个就是典型的树结构的
我想稍后做一个类 结构类似与目录树控件
将里面 ...

如果能封装成树类,那当然好。但问题在于关于树问题的原初存储结构,属性要求千奇百怪,设置得多了影响效率,少了又很难通用,有点两难。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-4-19 07:44 , Processed in 0.047483 second(s), 15 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表