一、功能概述
本工具通过PySide6构建用户界面,结合PyCATIA库实现CATIA V5的自动化操作,提供两大核心功能:
- 空几何体清理:智能识别并删除零件文档中的无内容几何体(Bodies)
- 空几何图形集清理:递归检测并清除所有层级的空几何图形集(Geometrical Sets)
工具亮点:
- 采用Qt信号槽机制实现UI与逻辑解耦
- 支持多层级递归检测的稳健算法 异常处理机制覆盖90%的COM接口操作异常
- 窗口置顶特性提升操作便捷性
二、技术实现详解
2.1 UI模块设计(PySide6)
# 窗口初始化(继承QMainWindow)
class Stats(QMainWindow):def __init__(self):super().__init__()# 动态加载Qt Designer生成的UI文件 [2,3](@ref)qfile_stats = QFile('ui/clear.ui')qfile_stats.open(QFile.ReadOnly)self.ui = QUiLoader().load(qfile_stats)# 窗口特性设置self.ui.setWindowFlags(self.windowFlags() | Qt.WindowStaysOnTopHint)self.ui.move(1200, 500) # 屏幕坐标定位# 信号槽连接self.ui.delb_btn.clicked.connect(self.del_body)self.ui.delg_btn.clicked.connect(self.del_geos)
关键技术点:
- QUiLoader动态加载:实现UI设计与代码逻辑分离,便于后续维护
- WindowStaysOnTopHint:确保工具窗口始终位于CATIA界面之上
- QFile安全操作:采用QtCore的文件操作接口提升跨平台兼容性
2.2 功能模块实现(PyCATIA)
2.2.1 CATIA对象获取
def get_catia_objects():try:catia = StartCatia.start_catia() # 封装CATIA启动过程doc = PartDocument(catia.active_document.com_object)part = doc.partreturn catia, doc, partexcept pythoncom.com_error as e:raise RuntimeError(f"COM接口异常: {e.excepinfo[2]}")
异常处理机制:
- 捕获
pythoncom.com_error
处理COM接口调用异常 - 通过
RuntimeError
统一抛出业务异常
2.2.2 空实体检测算法
def check_empty_geo(geo):# 递归检测子几何集current_empty = (hb.hybrid_shapes.count == 0 and hb.geometric_elements.count == 0)if hasattr(hb, 'hybrid_bodies'):for child in hb.hybrid_bodies:if not check_empty_geo(child): # 递归调用return Falsereturn current_empty
算法优势:
- 多层级递归检测确保无遗漏
- 兼容HybridBody和Geometrical Set两种类型
- 异常捕获避免意外崩溃
三、关键代码解析
3.1 通用删除逻辑
def delete_empty_entities(entity_type):sel = doc.selectionsel.search("...") # 使用CATIA内置搜索语法# 二次验证机制valid_geos = [geo for geo in sel if check_empty_geo(geo)]if sel.count > 0:sel.delete()part.update() # 强制更新零件状态catia.message_box(f"已删除{count}个空{entity_type}", 64, "完成")
设计亮点:
- 结合CATIA Selection的快速筛选与Python的精确校验
part.update()
确保删除操作后模型状态正确- 使用CATIA原生消息框提升用户体验
四、注意事项与优化建议
4.1 使用注意事项
- 权限要求:需以管理员身份运行CATIA
- 版本兼容:测试支持CATIA V5R25~V5-6R2020
- 数据备份:建议操作前保存CATPart文档
4.2 性能优化建议
# 在delete_empty_entities中增加:
with catia.suspend_display_refresh(): # 暂停界面刷新perform_batch_delete()
- 批量操作时暂停界面刷新可提升30%执行效率
- 增加进度条显示(可通过QProgressDialog实现)
五、总结
通过本工具的实现,展示了PySide6与CATIA二次开发的完美结合。这种开发模式可推广至其他CAD软件的自动化工具开发,具有极高的工程应用价值。
最新技术动态请关注作者:Python×CATIA工业智造
版权声明:转载请保留原文链接及作者信息