proe]族表使用详解.docx
proe族表使用详解proe族表使用详解族表是很多类似零件或组件或特征的集合,这些零件(组件/特征)从构造上看很类似,但在一些细节部份不同,比方尺寸大小或具体特征等。一个典型的例子就是螺钉、螺母,同一个标准(如GB/T819.1)里,会有多达上百种不同规格,但它们看起来是一样的并且具有一样的功能,所以我们把这上百种规格的螺钉看成是一个零件族。“族表(FamilyTable)中的零件也称表驱动零件。下列图(index.gif)是螺钉族。图的左面是普通模型,右面是它的实例。普通模型为父项。族表的作用:产生和存储大量简单而细致的对象把零件的生成标准化,既省时又省力从零件文件中生成各种零件,而无需重新构造能够对零件产生细小的变化而无需用关系改变模型产生能够存储到打印文件并包含在零件目录中的零件表族表实现了零件的标准化并且同一族表的实例互相之间能够自动互换。关于族表的许可Pro/ENGINEER模块许可证不同,允许实现的族表内容也不同。有Pro/FEATURE许可,能够:创立表驱动的自定义组,组特征尺寸能够是表驱动的、不变的或可变的。向零件“族表(FamilyTable)中添加表驱动的组。基本的Pro/ENGINEER许可,能够:通过向“族表(FamilyTable)中添加尺寸创立表驱动零件。Pro/ASSEMBLY许可,能够:通过添加“族表(FamilyTable)子组件、零件名称以及组件尺寸来创立表驱动的组件。族表构造族表,本质上是用电子表格来管理模型数据,它的外观体现也是一个由行和列组成的电子表格。还是用螺钉来讲,GB/T819.1里的上百种螺钉,外形都是一样的,只是尺寸有变化,比方螺纹规格、螺钉总长、螺纹长等等,在标准里,是这样描绘这些数据的:(1.gif)我们把这个表格变换一下,变成下面这样(部份数据):(2.gif)这个表里,第一行是表头,列出了各列的抬头,第二行起,每一行是一个规格的螺钉的详细尺寸,也就是讲,每一行是一个详细的螺钉规格,我们称之为一个实例,第一列是所有规格的螺钉的规格名,从每二列开场,每一列都是螺钉的一个尺寸参数的取值,我们称之为一个项或列。如今,我们建一个螺钉的模型,模型先随意用一个实例的参数来建,比方用M3x5的参数。建好后再建一个族表,将这个模型里的对应于上表的那些尺寸都参加到族表里,再把各个实例都参加表族表,最后的族表构造如下:(4.gif)可见,族表就是一个简单的电子表格。在这个电子表格里,表头的p、d、l、Dk、k等就是各个实例里要变化的项的代号,这些项最常见的是尺寸,可以以是特征、零件、参数、符号、阵列表、UDF等等。表头列就是每一个实例的名字,对第一个实例,它的名字就是模型的名字,这是不能在族表里改变的,其它的实例的名字,都是在族表里命名和修改的。第一个实例,实际就是当前模型,是所有其它实例的父模型,第一行里的所有项的值,也是直接调入当前模型的当前值(要修改也只能直接修改模型而不能修改第一行里各个项的值),其它所有实例的各个项的值,都是根据实际需要确定。多层族表上一节的族表(4.gif)是用一个表来管理所有数据。但我们能够看到,这个表里有些实例的某些项的取值是一样的,比方M3x4/M3x5/M3x6/M3x8/M3x10这五个实例,除了总长L这一项取值不同外,其它各项的值都是一样的,M2x5/M3x5/M4x5这三个实例互相之间差异比拟大,但也有一个一样取值的项。所以,我们能够再变换一下,见下列图(5.gif):在这个表里,只取了四个项,用这四个项将全部M2的规格合为一个实例,全部M3的规格合为一个实例,合部M4的规格合为一个实例。余下总长L这一项在这个表里不存在。接下来分别做这样三个表(6.gif):这三个表分别与前一表(5.gif)中的实例M2、M3、M4相关联,在Excel里,就是建一个链接,在PROE里,就是打开M2实例,在此实例里再建一个族表,族表内容即是上图的M2这个表(M3、M4同理)。这就是族表的层级,实例M2、M3、M4所在族表为父族表,其它三个族表是它的子族表。同理,子族表还能够有它的子族表,父族表也还能够有它的父族表,也就是讲,族表能够多级级联,见下列图(7.gif):但要注意:同一个对象(同一尺寸/参数/特征/参数表/UDF/元件)只能出如今同一分枝的同一级的族表里。比方尺寸K,它出现于二级族表1中,那么,在二级族表1的所有实例中定义的三级族表(及这些族表的实例中定义的更下级族表)里就不能再使用它,重定义其上级族表(及更上级族表)也不能再使用它;但假如它所依附的特征在定义二级族表K的实例K里存在并且它没在二级族表K中出现,那么它能够出现于二级族表K(或这个族表的实例所定义的某级下级族表)里。创立族表1.创立一个普通模型,作为原始模型来使用。2.创立族表:(2001):零件(组件)-族表;(WF):工具-族表。进入族表编辑器,如下列图(8.gif,2001、WF同一界面):3.参加项,点上图第二个彩色按钮(增加/删除表列),进入项目选取窗口,如下列图(9.gif,2001、WF同一界面):选取一个项目类型,再选取相应项目参加项目列表里。假如选错了,点减号按钮将其从项目列表里去掉。选择完毕点“确定返回族表编辑器。注意:族表编辑器里各个列项的排列,是根据选取的顺序排列的,所以最好选取时把相关项挨着选在一起,以免数据乱七八糟;并且最好给各个项对应的对象(尺寸、特征等)取个有点实际意义的名字,这些名字将在族表编辑器的表头里显示出来,便于以后的数据管理。4.参加实例行:点第2步图(8.gif)上的第一个彩色按钮(在所选行插入新的实例),编辑器里增加多个行,如下列图(10.gif):5.输入各新实例数据,把每一个实例对应的各个项的取值输入到表里。“实例名对应的那一列是每个实例的名字,在此为每个实例取个名字,将来用这个名字来调用这个实例。各个项输入的值,假如与第一行(原始模型的数据)的值一样,那么能够用一个星号(*)代替。注意一个细节:假如某个项是阵列的阵列数,那么子项取值为0的话,与用星号同效果(PTC的帮助上讲的是取值为0的话,实例连阵列的原始特征都不生成,与软件的实际情况不同)。6.输入完毕,校验实例。点上图右起第二个按钮(校验族的实例)。系统即开场运算,尝试生成每一个实例。校验完毕假如没有实例生成失败,族表定义就能够结束了,点工具栏上的小眼镜图标(预览选定实例)会弹出一个小窗口,能够预览实例的最后形状,点“打开能够在一个新窗口里打开一个实例;假如有实例校验失败,一般来讲是此实例的某些项的取值有误,影响了模型的生成,需要检查此实例的各项取值,修正错误。注:尺寸、参数、元件、特征的参加族表,都按上述经过参加即可,选取类型后,会有提示选取详细的尺寸、参数、元件、特征,“元件是只要在组件里才可用的。其它类型的参加族表及其管理,请参考后文。公差的使用与尺寸一样,假如尺寸有公差,开启公差显示,即可将公差当普通尺寸一样选取中入族表。创立多层族表1.创立原始模型。2.规划数据管理。根据原始模型的建模手法和各实例的详细变化,确定哪些项(尺寸、参数、特征、零件)要用族表进行管理,再根据各个项的变化情况确定哪些项放在第一级族表里,哪些项放在第二级族表里,假如数据很多,还可能要规划哪些放在第三级族表里(或更多级族表)。由于同一个项只能出如今族表树的某一个层级里,所以一个项位于哪个层级一定要规划好,否则后期数据录入量会很大,尽可能的把取值重复较多的项放在靠前的层级里。例如原始模型里有A、B、C、D、E五个尺寸,五个尺寸项取值组合共生成100个实例,那么怎样规划族表呢?方案A:只用一级族表,那么每个尺寸取值都要录入100次,需要输入数据5x100=500次。方案B:经分析后发现100个实例中A、B、C这三个尺寸组合重复较多,其不同组合只要5种,那么把A、B、C放在第一级族表,D、E放在第二级族表,则A、B、C这三个尺寸取值各只需录入5次,D、E这两尺寸还是需要各录入100次,总共需要输入数据5x3+100x2=215次。方案C:分析后也发现,100个实例中B、E这两个尺寸组合重复更多,其不同组合只要2种,那么把B、E放在第一级族表,A、C、D放在第二级族表,则B、E这两个尺寸取值各要录入2次,A、C、D这三个尺寸各要录入100次,总共需要输入数据2x2+100x3=304次。从以上的分析能够看到,不同的规划,数据录入量是差很远的。所以,在建族表之前先分析一下数据,确定一个较好的族表方案是很重要的,十分是在有大量实例的情况下。好的族表分级管理规划,不仅能大大减少数据录入量,降低错误发生率,还能为查找实例提供一个明晰明朗的指引,便于检索实例与修改数据。3.建立第一级族表。4.在族表编辑器里,选取第一级族表的某一个实例行,“插入-“实例层表,系统打开一个新的族表编辑器,根据上一节创立单层族表的步骤创立属于这个实例的二级族表。同理,创立其它实例的二级族表。创立完后,在原始模型里看到的族表编辑器如下:(12.gif)能够看到,带有子族表的实例行前都有一个文件夹标记,不带子族表的实例行前是没有的。要查看子族表的内容,能够在工具栏“查找的实例列表(这里只显示带有子族表的实例名)里找到那个子族表所依附的实例名并将其设为当前实例(默认情况下是本级族表的原始实例名,对第一级族表,就是原始模型名)。5.多层族表的第二种创立方法:在建立了第一级族表后,选中要参加子族表的实例,打开它,系统在一个新窗口打开所选实例,接下来在此窗口里根据上一节创立单层族表的步骤创立一个新族表,所创立的新族表就是依附于此实例的二级族表。更多层级族表创立同理。参考模型:GBT819_1.rar(装配体中所有元件被隐含,先打开零件再打开装配体反隐含)修改族表内容1.方式一:直接修改族表。也就是打开族表编辑器,直接修改族表里各实例的值。要注意一下的是星号(*)的使用,星号表示所选实例的这个项的取值与原始模型的值一样,假如原始模型变化,那么,实例也跟着变化,假如不想实例跟着原始模型变化,就不要使用星号。另外,对于阵列数这种尺寸值,实例里取值可以以是0(直接修改模型不能够是0的!),但假如取0的话,实际效果也是星号的效果。族表里的数值型项的取值,必须是一个确定的数值或星号(*),不能是一个范围或变量名;特征、元件、组、参照元件、合并零件、UDF等项的取值,能够是“Y、“N、“*或这个元素(无件、参照元件、合并零件、UDF)所带的子族表中的各个实例的实例名。族表里原始模型的各项值只能在模型窗口修改模型来实现,不能在族表里修改(也有例外,见下文)。2.方式二:修改实例模型。打开要修改的实例(“文件-打开-选取实例名或在族表编辑器里选中要修改的实例后点“打开),能够像普通模型一样修改实例模型。修改原始模型,如是非族表控制内容,则所有实例都被修改,如是族表控制内容,则仅对原始模型和项取值为星号(*)的实例有效。修改实例模型,影响如下:修改由族表控制的尺寸,系统会提示此尺寸由族表控制,确认后修改此尺寸,再生后族表自动更新此实例的取值;修改非族表控制的尺寸,系统没有任何提示信息,但所有实例连同原始模型的该尺寸都修改了;修改参数与修改尺寸类似,不管能否由族表控制,都没有提示信息,族表控制的参数修改再生后族表自动更新实例对应的项值,非族表控制的参数修改再后后,所有实例连同原始模型的值都修改了;隐含一个特征(元件),不管这个特征能否由族表控制,系统会提示隐含只是暂时有效,再生后特征就解除隐含,对族表没有任何影响。删除一个特征(元件),假如它有子特征,子特征也会一起被删除,这些被删除的特征,假如是由族表控制的,那么族表里该实例的值被更新为“N,假如不是由族表控制的,那么族表里会自动增加相应数目的新列,这些列对应原始模型的项值为“Y,对应此实例的项值为“N,对应其它实例的项值为“*;增加一个特征,族表里会自动增加一列,此列对应原始模型的项值为“N(注:这种情况下,可修改族表里原始模型的项值为“Y,假如所增加的特征能在原始模型中生成,那么再生后这个特征将被参加到原始模型里,-接下来,所有其它的实例也都由星号把这个特征参加进去),对应此实例的项值为“Y,对应其它实例的项值为“*;修改尺寸名、特征名等,会自动更新族表内容;给任何一个实例增加参考尺寸、几何公差、外表粗糙度,都会自动在所有实例及原始模型中增加;族表内容的阵列阵列族表内容,实际上是一种快速输入族表数据的方法,其作用是减少编辑族表的时间。当一个族表里的多个项内容按一定规律变化时,我们就不必一个个项的输入,能够用阵列来快速输入。因而,这里讲的“阵列,只是一个快速复制族表实例的方法,与建模的“阵列是完全不同的。1.创立族表,参加族表的各个列(项);2.创立一个实例,作为阵列复制的源,如下列图(16.gif):3.选中要阵列复制源实例,“编辑-“用增量复制,弹出设置窗口,如下列图(17.gif):4.在左侧项目列表里选中要增量变化的项,比方d0,点“)将其放入右侧列表里,并设定其增量为20;同样,将p7放入右侧列表,设定其增量为2。在方向数量里设定为5,结果如下列图(18.gif):5.上面例子为一个方向变化,当然可以以设定为多个方向变化,最终的变化与模型中多方向阵列的变化类似,可自行尝试体会。假如某项没有被参加到右侧列表并给定一个非零增量,那么该项的值在所有生成的实例中保持源实例的值。附:其它快速修改族表内容的方法:A.用Excel编辑,在族表编辑器里,“文件-“用Excel编辑当前表,系统启动Excel,并将当前表调入Excel内,然后像编辑普通Excel表那样编辑表,编辑完毕更新族表即可。要注意的是,机器上必须装有Excel程序,编辑好的表里不可有PROE不接受的字符或符号,在某些版本里,这种做法不能成功(编辑完后更新不了)。B.用记事本或其它编辑器编辑,在族表编辑器里,“文件-“输出表-“文本族表,系统将当前表存为一个文本格式的文件,文件名为“name_tmp.ptd(name为此族表的原始模型名,当然你可以以给它另外命名),然后用记事本或其它文本编辑器修改此文件,见下列图(19.gif):修改后保存,然后在族表编辑器里,调入刚刚修改的文件即可(“文件-“输入表)。要注意:文件保存时应保存为文本格式,不能带有PROE不接受的字符或符号;文件名应是“原始模型名_tmp.ptd,十分是在建多层族表时要注意,对于多层族表,这个“原始模型名应是当前定义的子族表的原始实例名,这是系统命名规则,当然你能够按本人的规则去命名,只要不会搞错就好;对于多层族表,好像一层级有多个族表,族表构造都一样,则能够保存一个原始的文本文件,再复制出多个文件,按命名规则命名,并编辑好内容,然后创立每一个实例的子族表,只需要按文本文件中的项目排列顺序参加表控项目(即创立一个表头),然后就能够读入此实例对应的文本文件。族表使用参照模型当一个元件(B)参照了组件(AB)中的另一个元件(A)或子组件时,它(B)所参照的这个元件(A)或子组件带有族表,则取不同实例(A1、A2、A3)时,此元件(B)也会跟着变化,在此情况下,我们能够使用族表控制“参照模型,给此元件(B)建一个族表,在此族表中定义与所参照的模型的实例相对应的实例。例见下(13.gif):零件A(L形)的两个直边厚度由族表控制,实例分别如下(分别对应上图中110、130长的直边):A135/25;A230/20;A325/15。在矩形零件B上创立一个直径30的孔,此孔轴线到零件A的外侧距离分别为60、50且固定不变。则当零件A取不同实例时,此孔在零件B上的位置是不同的。在此情况下,要给B创立一个族表确定此孔在每一个实例中的详细位置的话,就要用“参照模型来解决。步骤如下:1.创立零件A、B。2.零件A中创立族表,用族表控制两直边厚度尺寸,三个实例A1、A2、A3。3.创立装配体AB。4.在装配体AB中创立族表,用族表控制每一个实例中怎样取A的实例,三个实例AB1(取A1)、AB2(取A2)、AB3(取A3)。5.零件B中创立族表,选取项类型时选“参照模型,系统列出B所参照的文件名,选取AB.asm,确定。回族表编辑器,参加实例行,实例行中的各项取值分别为AB的实例名AB1、AB2、AB3,如下:(14.gif)6.编辑装配体AB的族表,参加一列以确定B的实例取值,各项分别为B的实例名B1、B2、B3,如下:(15.gif)7.结束,保存文件。