bootstracp实现树形列表_【GhPython】如何用GhPython实现树形数据的Mass Addition

​| 版权声明

| 作者:月之眼

| 首发于大水牛参数化设计平台

| 如需转载请联系作者

| 如果觉得文章不错,欢迎分享


问题背景

  • 今天有人在群里问“大佬们好,再请教大家一个问题,我想对每个路径进行求和,python中该如何操作?多谢了”。

310dd1b4389b1410a05b0798fb6bdba1.png

问题解答

简单介绍两种方法。

  • 第一种方法比较简单和常规。把输入类型设置为list,利用sum()函数直接对列表求和。

f9bac2130bac136fd79491b77816b3cd.png
  • 第二种方法比较传统,把输入类型设置为data tree,然后再把树形数据转换成嵌套列表,再对嵌套列表进行列表解析求和。

a4346477b803585eadbc405cf922cb7e.png

cc2c2c5607feeedd8584b0715f4ec68c.png

这里讲第二种方法主要是为了讲解一下,rhino6中自带的import ghpythonlib.treehelpers库。这个库中有两个方法tree_to_list(),这个方法是把树形数据转换成嵌套列表,list_to_tree(),这个方法是把嵌套列表转换成树形数据。下面我们简单自定义一个方法实现tree_to_list的效果。

f9cefdcb1c8f2e6474358a69c40d7c11.png

import ghpythonlib.treehelpers as ght

a = ght.tree_to_list(x,0)

def TreeToList(tree):

outlist=[list(tree.Branch(i)) for i in tree.Paths]

return outlist

b = TreeToList(x)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值