python二次开发CATIA:CATIA Automation

2023-10-19 08:28

本文主要是介绍python二次开发CATIA:CATIA Automation,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CATIA 软件中有一套逻辑与关系都十分严谨的自动化对象,它们从CATIA(Application)向下分支。每个自动化对象(Automation Object,以下简称Object)都有各自的属性与方法。我们通过程序语言调用这些 Object 的属性与方法,便可控制软件进行部分操作的自动进行。

1、Automation对象查找方法

Automation对象、属性和方法可以从一个叫做 CAA V5 Visual Basic Help 的文件中得到,这个文件存在与 CATIA 安装目录的 code/bin 路径下,文件名为 V5Automation.chm。

可以看到从最上面的 Application 向下有多个用不同颜色表示的子分支。并且有些蓝色对象的右侧带有红色箭头标志 ,点击该箭头可以展开并看以此 Object 为根节点的更深层的树状图。 接下来,我们对“对象 / Object”、“集合 / Collection”、“属性 /Property”、“方法 / Method”这四个概念加以说明。

1.1对象

在 CATIA 里,诸如文件,窗口,视图,视角,零件,草图,凸台特征,乃至直线曲线,这些以对象的形式存在。这种对象在树状图中会用蓝色表示。

1.2集合

集合,也是一种对象,只不过它是包含了其他对象的一种特殊对象。集合对象里包含的对象通常来说都是同一类型。举例来说, documents 集合里包含了 document 对象, 一个很好的识别集合对象的方式就是,它是对象 document 加了 s/es 的复数形式。树状图中的集合类对象用黄色表示。

1.3属性

属性主要是表达该对象有怎样的特征。举例来说, Document 对象,有个属性是FullName,它表示的就是该文件的完整路径,如“D:\xxx\Example1.CATPart” ,这是在我们通过代码打开/保存文件时必不可少的信息。通过读取对象的属性,我们才可以对同类对象加以区分,例如我们可以通过不同的 name 区分同样都是 Document 的两个对象。属性分为两种,一种是常规属性,我们可以读取它的信息,或是修改它的信息;另一种是只读属性,为了防止预期外的修改引起异常,有些对象会有只读属性,你仅可以读取它的值,但不能对其进行更改。读取或修改一个对象的属性值,格式为“对象.属性”。

同属性类似,获取某个对象也是通过“父级对象.子对象” 的方法。而对于 CATIAVBA,最大的父级对象就是 Application 也就是 CATIA。有了这个对象,我们“一路‘点’ 下去” 就可以轻松地获取自己想要的对象及属性。

1.4方法

所谓方法,就是你可以让对象执行某个动作。比如,你可以让当前激活的文档执行“保存” 这个动作。


2、关于宏录制

2.1录制宏的步骤

  1. 打开CATIA,关闭所有文档。
  2. 从菜单中选择“Tools——Macro——Star Recording”命令,以开始录制宏。
  3. 在弹出的记录宏对话框中选择宏的存贮位置、使用的语言,并定义宏的名称,单击确认按钮后,即开始宏的录制工作。
  4. 在录制过程中,可以随时单击“Stop宏录制”按钮。

2.2录制宏的局限性

宏录制是一种记录用户在软件中执行的一系列操作的方法,但这种方法存在一些局限性。

首先,并非所有的内容都会被录制下来。例如,一些对话框中的文本,或者图形界面中的某些元素,可能不会被宏录制下来。这样,录制的宏就无法完全复制用户在软件中的所有交互。

其次,默认的宏录制是不具备交互性的。也就是说,宏只会机械地完全重复之前录制的命令组合,无法与用户实现交互,也无法执行条件或循环语句。这样,录制的宏在执行时的功能就受到很大限制。

另外,宏录制通常无法处理复杂的工作流程或任务。在处理复杂任务时,可能需要更多的编程技巧和经验,才能实现所需的功能。

最后,宏录制可能存在一些安全风险。如果宏代码包含敏感信息,如用户名和密码等,这些信息可能会被恶意用户获取。因此,在使用宏录制时,需要注意信息安全问题。

总结:不是所有的手动操作都可以录制得到对应宏代码;不是所有手动操作,都有对应的 API。
 

3、Part Design 常用 Object 与 API

3.1文件操作

由于我们要进行 Part 里面的操作,所以获取到目标 PartDocument 是首要任务,进而才能获取它的 Part 对象及其子对象,并进行相关建模操作。想要得到一个 PartDocument,无非就是以下几种情况:
• CATIA 当前窗口打开的就是一个 Part 文档,直接获取它;
• 打开一个现有的 Part 文件;
• 没有 Part 文档,我们需要自己新建一个;
• 编辑装配里面的某个 Part。
 

# 获取 Application 的 Documents 对象
docs=catia.documents
# 获取 CATIA 当前激活的 Part 文件
partdoc1=catia.activedocument
# 创建一个新的 Part 文件,注意 P 要大写
partdoc2=docs.add('Part')
# 打开 D 盘的 mypart.CATPart 文件,路径前加 r 是为了防止将路径中的\解析为转义字符
partdoc3=docs.open(r'D:\mypart.CATPart')
# 获取装配里的 prd 部件对应的 Part 文件(仅限该部件为零件时)
partdoc4=prd.ReferenceProduct.Parent

3.2几何体操作

获取到文件之后,通过 PartDocument.Part 即可获取到 Part 对象。 从帮助文档中可以查到, Bodies 隶属于 Part 下面,其 Object 的树状图如下:

其中 Bodies 是 Collection 集合类,因此我们可以使用集合通用的 Add、 Item 等方法对其进行操作, 并且由于 Python 自身语法的原因,对于 Item 的方法,我们可以直接用中括号[]代替,不过要注意序号问题,如:
 

part=partdoc.part
bodies=part.bodies
# 获取第 3 个几何体,两种写法都 OK
body1=bodies.item(3)
body1=bodies[2]
#获取名为 Body.5 的几何体,两种写法都 OK
body2=bodies.item('Body.5')
body2=bodies['Body.5']
# 获取零件几何体
mainbody=part.mainbody
# 由于零件几何体一般为第一个, 因此下面的写法也 OK
mainbody=bodies[0]

对于 Body 的删除,我们通常用 Selection 对象实现,以下代码模拟选中 mybody对象并删除的操作。

sel=document.selection
sel.add(mybody)
sel.delete()

将某一几何体定义为工作对象的方法为:
 

part.inworkobject=mybody

3.3草图操作

草图中的操作可分为草图的创建、进入/退出编辑及线条的绘制、约束的添加等操作。

3.3.1草图创建

对于创建操作,我们可以用 Sketches 这个 Collection 对象的 Add 方法创建新草图。其中 Add 需要一个参数,即草图所在的平面,该参数需是一个 Plane Object 的Reference,并且经实际验证,直接使用 Plane Object 亦可。以下代码先获取了 Part 的三个原始坐标平面中的 xy 平面,并在上面创建草图, 此草图由 mybody 下面的 sketches 对象创建,故创建后出现在 mybody 下:

plane=part.originelements.planexy
sketches=mybody.sketches
mysketch=sketches.add(plane)

如果想创建定位草图,我们需先在支持平面上创建普通草图,再用 sketch 的SetAbsoluteAxisData 方法指定草图的定位信息。该方法需要一个包含 9 个数值元素的矩阵, 其中:
• 前三个值代表草图的原点坐标;
• 中间三个值表示草图 H 轴的方向向量;
• 最后三个值表示草图 V 轴的方向向量。
根据上述内容,我们不难写出下面的代码,实现在 xy 平面上创建一个 H 轴与 x 方向成 45°的草图:

sketch=sketches.add(xyplane)
arr=[0,0,0,0.707,0.707,0,-0.707,0.707,0]
sketch.SetAbsoluteAxisData(arr)

3.3.2线条的绘制

想在草图里绘制线条,首先要进入草图编辑状态, 即调用 Sketch 的 OpenEdition 方法,并且此方法会返回一个 Factory2D 对象,该对象有 CreateLine, CreateCircle 等方法可以实现线条的绘制。需要注意的是,我们在绘制完草图的线条之后,要用 Sketch 的CloseEdition 方法退出编辑状态,并进行 Part 的 Update 操作,这样才可以正常显示并使用这个草图进行后续操作。一段草图中画线、画圆的示例代码如下,其他线条的绘制方法, 读者可自行查阅帮助文档中的 API。

fact2d=sketch.OpenEdition()
# 画线,四个参数分别为线段起、止点的坐标
myline=fact2d.CreateLine(x1,y1,x2,y2)
# 画整圆,三个参数分别为圆心坐标与半径
mycircle=fact2d.CreateClosedCircle(centerx,centery,radius)
sketch.CloseEdition()
part.update()

3.3.3添加约束

约束的创建需要用到 Sketch 下面 Constraints 这个 Collection 的 Add 方法。该对象创建约束有三个方法: AddMonoEltCst, AddBiEltCst, AddTriEltCst,对应的功能分别为为单个元素创建约束(如固定 a) 、为两个元素创建约束(如 a 与 b 相切)、为三个元素创建约束(如 a、 b 关于 c 对称)。至于每个方法创建的具体约束类型,需要通过方法的参数来控制。需要说明的一点是,几何元素不能直接用于创建约束,必须为其创建参考对象,再使用参考对象创建约束。

以下代码实现的功能为创建直线和圆的相切约束。 其他类型约束创建方法及对应参数,请读者自行查阅帮助文档。

mycons=sketch.Constraints
# 创建元素的参考
ref1=part.CreateReferenceFromObject(myline)
ref2=part.CreateReferenceFromObject(mycircle)
# 创建相切约束,查阅帮助文档可知,相切: catCstTypeTangency 的枚举值为 4
tan_con=mycons.AddBiEltCst(4,ref1,ref2)

3.4实体建模操作

实体的生成(凸台、凹槽等)、修饰(倒角、拔模等)、变换(平移、旋转等),以及几何体间的布尔运算这些实体特征, 统称为 Shape,它可以通过 Part 下的ShapeFactory 对象的 Add 方法进行添加。并且, 对于每个具体的 Shape 特征, 我们可以通过该 Shape 的子对象或属性进行相关参数的进一步设置。例如,下图为帮助文档中, Pad(凸台)对象的子对象。

sf=part.shapefactory
# 用 mysketch 拉伸凸台,高度为 50
mypad=sf.addnewpad(mysketch,50)
# 设置凸台的第二限制为-25
mypad.secondlimit.dimension.value=-25

Body 对象下面有 Shapes 这个 Collection 对象,每个 Shape 都属于这个Collection。同其他 Collection 对象一样,我们可以通过 Index 或 Name,获取到其内部指定的特征,如:

# 获取 Body 下的第 4 个特征
shape1=Body.shapes[4]
# 获取 Body 下名为 Pad.2 的特征
shape2=Body.shapes['Pad.2']


 

这篇关于python二次开发CATIA:CATIA Automation的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/238585

相关文章

VSCode配置Anaconda Python环境的实现

《VSCode配置AnacondaPython环境的实现》VisualStudioCode中可以使用Anaconda环境进行Python开发,本文主要介绍了VSCode配置AnacondaPytho... 目录前言一、安装 Visual Studio Code 和 Anaconda二、创建或激活 conda

pytorch+torchvision+python版本对应及环境安装

《pytorch+torchvision+python版本对应及环境安装》本文主要介绍了pytorch+torchvision+python版本对应及环境安装,安装过程中需要注意Numpy版本的降级,... 目录一、版本对应二、安装命令(pip)1. 版本2. 安装全过程3. 命令相关解释参考文章一、版本对

讯飞webapi语音识别接口调用示例代码(python)

《讯飞webapi语音识别接口调用示例代码(python)》:本文主要介绍如何使用Python3调用讯飞WebAPI语音识别接口,重点解决了在处理语音识别结果时判断是否为最后一帧的问题,通过运行代... 目录前言一、环境二、引入库三、代码实例四、运行结果五、总结前言基于python3 讯飞webAPI语音

基于Python开发PDF转PNG的可视化工具

《基于Python开发PDF转PNG的可视化工具》在数字文档处理领域,PDF到图像格式的转换是常见需求,本文介绍如何利用Python的PyMuPDF库和Tkinter框架开发一个带图形界面的PDF转P... 目录一、引言二、功能特性三、技术架构1. 技术栈组成2. 系统架构javascript设计3.效果图

Python如何在Word中生成多种不同类型的图表

《Python如何在Word中生成多种不同类型的图表》Word文档中插入图表不仅能直观呈现数据,还能提升文档的可读性和专业性,本文将介绍如何使用Python在Word文档中创建和自定义各种图表,需要的... 目录在Word中创建柱形图在Word中创建条形图在Word中创建折线图在Word中创建饼图在Word

Python Excel实现自动添加编号

《PythonExcel实现自动添加编号》这篇文章主要为大家详细介绍了如何使用Python在Excel中实现自动添加编号效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍简单的说,就是在Excel中有一列h=会有重复

Python FastAPI入门安装使用

《PythonFastAPI入门安装使用》FastAPI是一个现代、快速的PythonWeb框架,用于构建API,它基于Python3.6+的类型提示特性,使得代码更加简洁且易于绶护,这篇文章主要介... 目录第一节:FastAPI入门一、FastAPI框架介绍什么是ASGI服务(WSGI)二、FastAP

Python中Windows和macOS文件路径格式不一致的解决方法

《Python中Windows和macOS文件路径格式不一致的解决方法》在Python中,Windows和macOS的文件路径字符串格式不一致主要体现在路径分隔符上,这种差异可能导致跨平台代码在处理文... 目录方法 1:使用 os.path 模块方法 2:使用 pathlib 模块(推荐)方法 3:统一使

一文教你解决Python不支持中文路径的问题

《一文教你解决Python不支持中文路径的问题》Python是一种广泛使用的高级编程语言,然而在处理包含中文字符的文件路径时,Python有时会表现出一些不友好的行为,下面小编就来为大家介绍一下具体的... 目录问题背景解决方案1. 设置正确的文件编码2. 使用pathlib模块3. 转换路径为Unicod

Python结合Flask框架构建一个简易的远程控制系统

《Python结合Flask框架构建一个简易的远程控制系统》这篇文章主要为大家详细介绍了如何使用Python与Flask框架构建一个简易的远程控制系统,能够远程执行操作命令(如关机、重启、锁屏等),还... 目录1.概述2.功能使用系统命令执行实时屏幕监控3. BUG修复过程1. Authorization