QQ登录

只需一步,快速开始

登录 | 注册 | 找回密码

三维网

 找回密码
 注册

QQ登录

只需一步,快速开始

展开

通知     

查看: 12088|回复: 30
收起左侧

[分享] 工程图中用宏填写切割清单每行的总重

[复制链接]
发表于 2016-3-14 15:56:58 | 显示全部楼层 |阅读模式 来自: 中国四川攀枝花

马上注册,结识高手,享用更多资源,轻松玩转三维网社区。

您需要 登录 才可以下载或查看,没有帐号?注册

x
本帖最后由 pzhzshun 于 2016-3-15 16:32 编辑 6 T# Y; U6 Y" J* ?) z

* b. m: C% }7 S- ~  前段时间,在这个贴子里:http://www.3dportal.cn/discuz/forum.php?mod=redirect&goto=findpost&ptid=1253110&pid=8713151&fromuid=73388根据丹大的帮助,学会了用宏把切割清单里每个零件的总重写入到属性中。解决了手工填写每行焊件总重的问题。4 {% L2 |2 H) d  P" z# P& D
  用了一段时间,感觉这种写入总重的方式还是有些不妥的地方:修改了焊件的尺寸后,每次都要运行宏把总重写入属性里。如果忘记运行宏,那么工程图中切割清单里每行的总重就是错误的。8 C, O7 q* @0 W% V
  为避免每次修改焊件尺寸都要运行宏写入总重的弊端,就考虑用宏把每行总重的计算公式,直接写在工程图切割清单,总重的那一单元格中。
% l( V9 d7 o- R. N: M  B  用我可怜的 E 文知识,在 API 帮助里查询了许久,终于找到了工程图切割清单中填写内容的代码。
" x( c. W$ z" |0 t3 X  {  独乐乐不如众乐乐,这里把代码分享一下:- x" L: E, ]. D3 Q3 x4 l
  1. Option Explicit
    ! Y) w6 C, h& H4 {2 _
  2. Dim swApp As SldWorks.SldWorks0 s0 D% Y. D6 r, q" g3 Z7 W
  3. Dim swDraw As SldWorks.DrawingDoc6 l& C6 [. {+ V: @4 `, j
  4. Dim swView As SldWorks.View
    " X8 A: }/ T" T+ G7 @: R: \
  5. Dim swTable As SldWorks.TableAnnotation  C* ?1 g& p& _( f4 e
  6. Dim nNumRow As Long# a; g3 t$ j  _9 g' A7 D
  7. Dim i As Long
    & h+ l# ?8 N6 p' d8 g" d. x, w7 U4 n
  8. Sub main()
    / L, z3 z1 E; n2 G4 ~4 @
  9.     Set swApp = Application.SldWorks
    ) o+ s  S. R: f  [. }5 ]
  10.     Set swDraw = swApp.ActiveDoc
    ' O  R- d  s* Z# F
  11.     Set swView = swDraw.GetFirstView
    2 k1 p, i; g) q: ]
  12.     Do While Not swView Is Nothing
    4 f& U; O' c+ d& u5 s' K
  13.         Set swTable = swView.GetFirstTableAnnotation$ l( P& X% m4 v3 G
  14.         Do While Not swTable Is Nothing. [/ i* E8 D" y! b3 m$ `( ^
  15.             nNumRow = swTable.RowCount '获取切割清单行数
    : v" ^- {# X9 U% w' _0 M' I3 T
  16.             For i = 0 To nNumRow - 2
    # t" f8 c' M6 _" `; n
  17.                 swTable.Text(i, 6) = "={2}D" & i + 1 & "*F" & i + 1 '写入总重方程式到切割清单
    & J/ j, P; E# T" V
  18.             Next i7 o. D) V- _& M% {+ Y
  19.             Set swTable = swTable.GetNext
    2 a9 H8 ]: N: @. E% V- Z. Y
  20.         Loop
    0 v6 _! W3 |! g/ I: {" F* D1 g
  21.         Set swView = swView.GetNextView$ U3 \; n. b" q4 g4 c" ~" L8 _+ b
  22.     Loop9 x9 a; b+ p9 z* M* U
  23. End Sub* P5 p& ]( t# k8 F* H  {
复制代码

$ ]0 l8 d3 X) X( E* h, |如果不愿意复制粘贴,那就下载这个吧: 工程图切割清单填写每行焊件总重.rar (6.48 KB, 下载次数: 338)

评分

参与人数 1三维币 +3 收起 理由
阿帕奇 + 3

查看全部评分

发表于 2016-3-14 18:29:51 | 显示全部楼层 来自: 中国四川攀枝花
很不错,还是应该向师傅多学习,极不懂的地方多问问,对自己也所帮助提高,在此还应万分感谢师傅。
发表于 2016-3-14 19:16:02 | 显示全部楼层 来自: 中国辽宁
谢谢分享好方法,给楼主一个大大的赞。
发表于 2016-3-14 19:40:51 | 显示全部楼层 来自: 中国广东揭阳
感谢热心分享
发表于 2016-3-14 20:59:07 | 显示全部楼层 来自: 中国河南郑州
不错实用的工具
发表于 2016-3-15 11:21:47 | 显示全部楼层 来自: 中国台湾
讚一個!舉一反三!謝謝樓主分享。
 楼主| 发表于 2016-3-15 11:43:00 | 显示全部楼层 来自: 中国四川攀枝花
gt.adan 发表于 2016-3-15 11:21  u- U! H  \2 x/ _( l1 X2 L/ t( b
讚一個!舉一反三!謝謝樓主分享。

/ A$ @0 u4 |. I3 r- y感谢丹大的大力支持!
发表于 2016-3-15 13:08:47 | 显示全部楼层 来自: 中国广西桂林
很实用的工具,谢楼主!
发表于 2016-3-15 15:09:59 | 显示全部楼层 来自: 中国台湾
其實,樓主可以搜一下「常駐宏」及「特徵宏」,悶大都有很完整說明及教學/ X1 w' E1 Q$ r! ]. j6 {
一來無需在工程中圖再運行另一個宏來填寫方程,二來能徹底解決無法自動更新的問題。
 楼主| 发表于 2016-3-15 16:32:10 | 显示全部楼层 来自: 中国四川攀枝花
gt.adan 发表于 2016-3-15 15:09
7 T  z/ e# B) L% c' `* h/ b其實,樓主可以搜一下「常駐宏」及「特徵宏」,悶大都有很完整說明及教學
1 a0 S% J# F) Z1 M7 A, y一來無需在工程中圖再運行另一個 ...

; A, d& E' k' }: ~  ]4 u/ Y' {本论坛里搜索不到『常驻宏』和『特征宏』的资料,到开思去找到了闷大的原帖:
7 `1 \. k: ?( N) Zhttp://bbs.icax.org/thread-911488-1-2.html
% Y: g( S% Q- L+ @( q感觉用常驻宏来更新比特征宏要好一些,闷大的常驻宏切换窗口就运行一下,这样就不用手动去更新总重了,真正做到了一劳永逸。# }6 s: N# H8 N$ m$ v6 d0 B+ `& n
非常感谢丹大的提示!
发表于 2016-4-20 17:18:49 | 显示全部楼层 来自: 中国辽宁大连
这个16的代码在12中运行出问题,提示如图
- X8 G+ P1 ^; f 2.jpg 1.jpg 1 y, C( {" r8 l$ `, z9 V& {8 m" u
+ i/ `/ }% o) Y1 c
发表于 2016-4-21 15:29:10 | 显示全部楼层 来自: 中国辽宁大连
hexiaohuihex 发表于 2016-4-20 17:180 D2 C  A2 R* c8 V
这个16的代码在12中运行出问题,提示如图

: k) |+ z' G$ u2 l! ^2 S4 H已解决,是我自己拷贝代码的过程中一些乱码一同拷入,没删干净导致宏不认。" `1 m! L7 E# Z: O
已正常运行,多谢楼主了
发表于 2016-4-21 20:21:19 | 显示全部楼层 来自: 中国山东
对于焊接切割清单计算总重的这个问题,闷大在别网有一个能彻底解决总重的问题,而且如果配合常驻宏还能一劳永逸,楼主研究的精神是好,但是如果想彻底解决这个问题,还是建议楼主去拜读闷大的,[总重宏],相信楼主会深有感触。
发表于 2016-4-21 21:05:02 | 显示全部楼层 来自: 中国安徽蚌埠
觉得好奇怪!7 c8 r8 i( r2 _) Z* @
我在焊接件的模板属性制作时,先添加焊接->添加属性,如图 0421.png
8 L  o. y2 A$ F- z, H$ c1 B# d4 w
% [% u" j4 _' @9 W* S6 \) V画好焊件1 [6 p: N6 N) j3 F; h' x, t: @$ Q
设置材料,子实体的属性自动出现
9 y5 V' u' @- R4 M) j' ]- k3 r 04212.png
3 ]) T3 R* V% U& P1 o! o* T2 v8 c6 x( L
看总重在文件属性
! S  d8 W, r. Z: G8 I1 [ 04213.png . ]1 @, B9 n& Y& R0 G  l

/ S% j9 ^& W: z( D- Y( C没有什么难度的啊
% |; e4 A9 Q. m具体效果' A) q0 B5 O  A& O9 L4 a

% S7 @* I- N2 ] 171433wvjx2uapsb4xj447.gif $ v5 V  Y1 X% W$ j8 _+ [
  X% }! @" Y8 h. {! [% H
0 z6 T6 ?0 n3 m) ]1 @

评分

参与人数 1三维币 +5 收起 理由
不靠谱的江静 + 5 应助

查看全部评分

发表于 2016-4-22 18:24:37 | 显示全部楼层 来自: 中国天津
jinqin11 发表于 2016-4-21 21:05
: \. X: @; X8 v3 ]4 _2 X觉得好奇怪!
6 W# b' M9 m3 o( P" k4 x3 p( z我在焊接件的模板属性制作时,先添加焊接->添加属性,如图
! a% u; ]6 A5 A& P
材料明细表和焊件切割清单的区别在于,焊件切割清单可以直接提取焊件的轮廓属性(如果需要甚至还可以直接提取某一焊接件长度),比如说,“∠5*5"但是用材料明细表就不能达到这个目的。。。而且,对于专业做焊接结构的人来说,焊接清单比材料切割清单好很多很多。
发表于 2016-5-27 21:41:14 | 显示全部楼层 来自: 中国北京
你好  我下载了你上传的压缩包   然后在工程图里点工具  宏  运行  选择到解压后的代码   点击运行怎么提示找不到工程或库     我用的2015版的
发表于 2016-7-25 22:21:26 | 显示全部楼层 来自: 中国上海
支持   ````````````
发表于 2016-8-10 21:49:02 | 显示全部楼层 来自: 中国广东潮州
谢谢分享。
发表于 2018-3-2 15:54:50 | 显示全部楼层 来自: 中国河北唐山
好东西。能不能在公式上面加上获取“数量”,“单重”,“总重”所在的列,然后在用这个公式啊
发表于 2018-3-5 15:04:20 | 显示全部楼层 来自: 中国上海
这个宏不错,下载研究了
发表于 2018-3-9 08:47:19 | 显示全部楼层 来自: 中国湖南
好象用不了
发表于 2018-3-9 15:07:17 | 显示全部楼层 来自: 中国湖南
直接运行这个下载的宏sw2017没反应,用VB运行出现如下情况:* a6 c" `/ k1 ^. k; o

2 D! U. ?2 O4 Z
捕获.JPG
发表于 2018-3-9 16:29:36 | 显示全部楼层 来自: 中国湖南
这个完全是利用sw宏运行的,也没反应% ?6 N, S  [: ?. G( H

6 W  n7 F1 X4 Z7 T
捕获2.JPG
发表于 2018-3-9 16:36:37 | 显示全部楼层 来自: 中国湖南
是标题栏的属性名称不匹配?
发表于 2018-3-9 17:00:58 | 显示全部楼层 来自: 中国湖南
搞定,是我的表格跟楼主的不一样
发表回复
您需要登录后才可以回帖 登录 | 注册

本版积分规则


Licensed Copyright © 2016-2020 http://www.3dportal.cn/ All Rights Reserved 京 ICP备13008828号

小黑屋|手机版|Archiver|三维网 ( 京ICP备2023026364号-1 )

快速回复 返回顶部 返回列表