Dynamo批量修改多文件项目基点参数

Hello 大家好!我是九哥~

前几天群里有个小伙伴,咨询了我一个问题:如何批量修改多个 Revit 文件的项目基点?

本来是想帮忙改改程序,奈何打开以后,我看到了无数的节点和连线,而且这个问题,主要是因为 Transaction 的问题,代码应该更容易一些~


那么我们就来一起解决下这个,本次教程呢,主要是讲解如何完全通过代码来解决这个事,最后你会发现,用代码解决这个事,就会变得超级简单了~

一、获取 Revit 项目文件

第一步比较简单,用自带的几个节点一连就好,如下图,我这里为了便于多次测试,把带 “000” 的文件过滤了一下:

二、后台打开 Revit 文件

我们打开 API 手册,搜索 Application,能够找到如下三种方法,我们选择按路径和选项打开文件:

大意呢,就是需要一个模型路径和打开选项,我们分别看下。

(1)字符串路径转换为 ModelPath

首先我们需要将字符串的文件路径转化为 ModelPath,在 API 手册里搜索 ModelPathUtils,就能找到相关的转换方法,我们选择

ConvertUserVisiblePathToModelPath() 方法:

基本代码如下:

#获取文件路径,并后台打开文件,获取document
modelPath = ModelPathUtils.ConvertUserVisiblePathToModelPath(i)
d = app.OpenDocumentFile(modelPath, options)

(2)打开选项

在第二步的 Application 方法下,直接点击 OpenOptions 即可跳转相关页面:

这里重点关注下面这个选项,是否分离中心文件:

继续点进去,可以看到DetachFromCentralOption 的枚举:

这里我就简单选择第二个,打开并分离中心文件,实际按需选择即可。代码如下:

#打开文件的选项
options = OpenOptions()
options.DetachFromCentralOption = DetachFromCentralOption.DetachAndPreserveWorksets

三、获取项目基点

这里用到 System.Enum.ToObject 方法,大家记住即可,就不过多讲解了,用此方法将输入的 Category 转换为 BuiltInCategory。

然后就可以用过滤器,过滤出所需的图元了,代码如下:

#将Category转换为BuiltInCategory,并获取项目基点
bic = System.Enum.ToObject(BuiltInCategory, cat.Id)
element = FilteredElementCollector(d).WhereElementIsNotElementType().OfCategory(bic).ToElements()[0]

四、开启和关闭时事务

由于我们要更改项目基点的参数,开启事务是必须的,很多小伙伴都会用网上万能模板里提供的 Dynamo 开启和关闭事务方法,这里呢,我就直接调用 API 的方法了,可以参考之前的文章《如何让撤销栏显示 Dynamo 的具体操作内容》,介绍了 Transaction 相关内容。

#尝试开启事务
t = Transaction(d,'设置项目基点参数')
t.Start()

#关闭事务
t.Commit()

五、解锁和锁定项目基点

大多数情况下,Revit 默认的项目基点都是锁定状态的,这样如果我们用 Dynamo 设置项目基点参数,是无法完成的,会提示你图元被锁定。

在 API 手册中直接搜索 Pinned 就能找到图元锁定的方法,可 get 可 set,如下图:

那么我们就可以先解除锁定,在设置完参数以后再给他锁上,代码如下:

#解锁项目基点
element.Pinned = False

#锁定项目基点
element.Pinned = True

六、设置项目基点参数

这里呢,我也就简单写了,直接采用 LookupParameter 的方法,毕竟也不涉及多语言版本等问题,就是演示下思路,只需要写一个循环即可,代码如下:

#循环参数名称,并设置项目基点参数
r = []
for p,v in zip(parameter_names,values):
  data = element.LookupParameter(p).Set(v)

七、关闭和保存

直接在 API 手册里搜索 Document,就能看到 Close 的方法,如下图:

到这里我们的程序基本就完成了,如果你想让程序更完美,可以再加一个 try...except...,来更好的输出错误报告,代码如下:

#返回错误报告
import traceback
errorReport = traceback.format_exc()

这样我们本次教程的代码就写完了,最后附上完整的代码和节点截图,如下:

import clr
from System.Collections.Generic import *
import System

clr.AddReference('RevitServices')
import RevitServices
from RevitServices.Persistence import DocumentManager
from RevitServices.Transactions import TransactionManager

clr.AddReference('RevitAPI')
import Autodesk
from Autodesk.Revit.DB import *

doc = DocumentManager.Instance.CurrentDBDocument
app = doc.Application

def tolist(x):
    if hasattr(x,'__iter__'): return x
else : return [x]

filePath = tolist(IN[0])
cat= IN[1]
parameter_names = tolist(IN[2]) 
values = tolist(IN[3])


options = OpenOptions()
options.DetachFromCentralOption = DetachFromCentralOption.DetachAndPreserveWorksets

docOnDisk = []
items = []
result = []

for i in filePath:
    
    modelPath = ModelPathUtils.ConvertUserVisiblePathToModelPath(i)
    d = app.OpenDocumentFile(modelPath, options)  
    
    bic = System.Enum.ToObject(BuiltInCategory, cat.Id)
    element = FilteredElementCollector(d).WhereElementIsNotElementType().OfCategory(bic).ToElements()[0]
    try:
        
        t = Transaction(d,'设置项目基点参数')
        t.Start()
        
        element.Pinned = False
        
        r = []
        for p,v in zip(parameter_names,values):
            data = element.LookupParameter(p).Set(v)
            
            r.append(data)
            
            element.Pinned = True
            
        t.Commit()  
        result.append(r)
    except:
                
        import traceback
        errorReport = traceback.format_exc()
        result.append(errorReport)
                
    d.Close(True)
                
OUT = result

tips:

注意,由于我这里用的 LookupParameter 方法设置的参数,所以就涉及 Revit 内部单位问题,这里我就没做处理,直接用 Dynamo 的单位转换节点了,如下图:

好了,今天的教程就到这里了,小伙伴们快去尝试吧~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/391330.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

WordPress站点成功升级后的介绍页地址是什么?

我们一般在WordPress站点后台 >> 仪表盘 >> 更新中成功升级WordPress的话,最后打开的就是升级之后的版本介绍页。比如boke112百科前两天升级到WordPress 6.4.2后显示的介绍页如下图所示: 该介绍除了介绍当前版本修复了多少个问题及修补了多少…

爬虫-华为云空间备忘录导出到docx-selenium控制浏览器行为-python数据处理

背景适用情况介绍 老的荣耀手机属于华为云系统,家里人换了新荣耀手机属于荣耀云系统无法通过云空间将备忘录转移到新手机,不想让他们一个一个搞,于是整了一晚上想办法爬取下来。从网页抓取下来,然后存到docx文档中(包…

WordPress主题YIA移动端文章页的面包屑不显示怎么办?

平时我们一般都会在文章页导航菜单下方显示面包屑,类似于“当前位置:boke112百科 WordPress 正文”。平时用浏览器调试站点的时候,在Edge浏览器的“切换设备仿真”中,不管是选择什么设备都会显示面包屑。具体如下图所示&#xf…

四种mfc140u.dll丢失的解决方法,有效恢复mfc140u.dll丢失

mfc140u.dll文件的重要性,当系统中出现mfc140u.dll丢失的情况时,可能会导致一系列问题和影响。因此,保持mfc140u.dll文件的完整性对于系统和应用程序的稳定运行至关重要。一旦出现mfc140u.dll文件丢失的情况,我们需要采取有效的方…

Karnaugh map (卡诺图)

【Leetcode】 289. Game of Life According to Wikipedia’s article: “The Game of Life, also known simply as Life, is a cellular automaton devised by the British mathematician John Horton Conway in 1970.” The board is made up of an m x n grid of cells, wh…

mfc140u.dll文丢失导致应用程序无法正常,有哪些解决办法

mfc140u.dll是Microsoft Foundation Classes(MFC)的一个重要组件,它提供了许多用于开发Windows应用程序的功能和工具。然而,当系统或应用程序升级、恶意软件感染或文件损坏以及用户错误操作等情况发生时,mfc140u.dll文…

C/C++内存管理详解

目录 一、C内存分布 二、C语言与C内存管理方式 1、C语言中动态内存管理方式:malloc/calloc/realloc/free 2、C中的内存管理方式:new/delete 三、operator new与operator delete函数 1、函数概念: 2、函数使用: 3、底层原理…

【机器学习笔记】12 聚类

无监督学习概述 监督学习 在一个典型的监督学习中,训练集有标签𝑦 ,我们的目标是找到能够区分正样本和负样本的决策边界,需要据此拟合一个假设函数。无监督学习 与此不同的是,在无监督学习中,我们的数据没…

4 月 9 日至 4 月 10 日,Hack.Summit() 2024 首聚香江

Hack.Summit() 是一系列 Web3 开发者大会。2024 年的活动将于 2024 年 4 月 9 日至 4 月 10 日在香港数码港举行。自十年前首次举办以来,此次会议标志着 Hack.Summit() 首次在亚洲举办,香港被选为首次亚洲主办城市,这对 Hack VC 和该地区都具…

BuildAdmin - 免费开源可商用!基于 ThinkPHP8 和 Vue3 等流行技术栈打造的商业级后台管理系统

一款包含 PHP 服务端和 Vue 前端代码的 admin 管理系统,实用性很强,推荐给大家。 BuildAdmin 是一个成熟的后台管理系统,后端服务采用 ThinkPHP8 ,数据库使用 Mysql,前端部分则使用当前流行的 Vue3 / TypeScript / Vi…

Netty Review - ByteBuf扩容机制源码解析

文章目录 Pre概述前置知识: 名词解释writeByte 源码解析实现ensureWritable0(minWritableBytes)ensureWritable0alloc().calculateNewCapacity 总结 Pre Netty Review - 直接内存的应用及源码分析 Netty Review - 底层零拷贝源码解析 Netty Review - ByteBuf内存…

python - OSError:错误没有名为 [‘pytorch_model.bin‘

python - OSError:错误没有名为 [‘pytorch_model.bin’] 自己训练的模型存储好了以后 model MT5ForConditionalGeneration.from_pretrained(“ner/best”) 之前还可以跑 现在报错 错误没有名为 [‘pytorch_model.bin’] 还原了一下conda env 把四版变成三版了 …

人工智能学习与实训笔记(十五):Scikit-learn库的基础与使用

人工智能专栏文章汇总:人工智能学习专栏文章汇总-CSDN博客 本篇目录 一、介绍 1. 1 Scikit-learn的发展历程及定义 1.2 理解算法包、算法库及算法框架之间的区别和联系 二、Scikit-learn官网结构 三、安装与设置 3.1 Python环境的安装与配置 3.2 Scikit-lea…

【精选】Java面向对象进阶——接口细节:成员特点和接口的各种关系

🍬 博主介绍👨‍🎓 博主介绍:大家好,我是 hacker-routing ,很高兴认识大家~ ✨主攻领域:【渗透领域】【应急响应】 【Java】 【VulnHub靶场复现】【面试分析】 🎉点赞➕评论➕收藏 …

1.逆向基础

文章目录 一、前言二、什么是逆向?三、软件逆向四、逆向分析技术五、文本字符六、Windows系统1.Win API2.WOW643.Windows消息机制4.虚拟内存 一、前言 原文以及后续文章可点击查看:逆向基础 逆向真的是一个很宏大的话题,而且大多数都是相当…

从代码的层面掌握LLM的路线

原则:从易到难,只用 pytorch 从第一个项目来熟悉 transformer 的使用; 从第二个项目来掌握对训练数据的使用方法及 transformer 的 decoder 的细节; 从第三个项目来理解 LLM 的整个过程; 1,Transformer t…

2024/2/17 图论 最短路入门 dijkstra 1

目录 算法思路 Dijkstra求最短路 AcWing 849. Dijkstra求最短路 I - AcWing 850. Dijkstra求最短路 II - AcWing题库 最短路 最短路 - HDU 2544 - Virtual Judge (vjudge.net) 【模板】单源最短路径(弱化版) P3371 【模板】单源最短路径&#xf…

echarts制作两个柱状图

let colorList[#02ce8b,#ffbe62,#f17373]; let data1 [90,80,70,50] option { title:[{ // 第一个标题text: 环保检测, // 主标题textStyle: { // 主标题样式color: #333,fontWeight: bold,fontSize: 16},left: 20%, // 定位到适合的位置top: 10%, // 定位到适合的位置},{ //…

【plt.scatter绘制散点图】:从入门到精通,只需一篇文章!【Matplotlib】

【plt.scatter绘制散点图】:从入门到精通,只需一篇文章!【Matplotlib】!🚀 利用Matplotlib进行数据可视化示例 🌵文章目录🌵 一、plt.scatter入门:轻松迈出第一步 👣二、…

各类电纸书使用体验

对移动阅读一直有着强烈的愿望,想要一个易于携带,又能看着比较大气的电子阅读器,这是一个矛盾...所以现在用着海信Hi Reader Pro,还想再寻找一个合适的家用阅读器,对自己用过的阅读器总结一下,给大家做个参…