QQ登录

只需一步,快速开始

登录 | 注册 | 找回密码

三维网

 找回密码
 注册

QQ登录

只需一步,快速开始

展开

通知     

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

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

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

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

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

x
本帖最后由 pzhzshun 于 2016-3-15 16:32 编辑
: a  \$ u2 v9 p1 N: c3 q5 L  k( H" H( {" |8 `: X5 D
  前段时间,在这个贴子里:http://www.3dportal.cn/discuz/forum.php?mod=redirect&goto=findpost&ptid=1253110&pid=8713151&fromuid=73388根据丹大的帮助,学会了用宏把切割清单里每个零件的总重写入到属性中。解决了手工填写每行焊件总重的问题。) \. z+ Q& u: C: S$ J6 C% O' m; E
  用了一段时间,感觉这种写入总重的方式还是有些不妥的地方:修改了焊件的尺寸后,每次都要运行宏把总重写入属性里。如果忘记运行宏,那么工程图中切割清单里每行的总重就是错误的。
, [* Q, w. M2 j9 {  为避免每次修改焊件尺寸都要运行宏写入总重的弊端,就考虑用宏把每行总重的计算公式,直接写在工程图切割清单,总重的那一单元格中。+ U' |& _; m& J2 W1 ^
  用我可怜的 E 文知识,在 API 帮助里查询了许久,终于找到了工程图切割清单中填写内容的代码。
/ k2 H4 L+ D# S. j* t. j; K' D) A  独乐乐不如众乐乐,这里把代码分享一下:
! z5 ^. _6 Q& R+ y9 ^' f/ ^# V) ?% r
  1. Option Explicit
    5 v& s' i0 l$ Q
  2. Dim swApp As SldWorks.SldWorks3 M0 j) G. {8 O) J
  3. Dim swDraw As SldWorks.DrawingDoc
    # j% o: V5 z. e  w2 t2 b, U
  4. Dim swView As SldWorks.View
    3 \6 ^1 N/ B1 N' A! Q! b
  5. Dim swTable As SldWorks.TableAnnotation% _  ^+ ]3 y. m
  6. Dim nNumRow As Long
      ]7 g$ H  J8 E7 R% W% H% |
  7. Dim i As Long
    5 _6 I& D4 P5 Y0 Q/ {+ w
  8. Sub main(): |& C" l2 m" i5 c) h
  9.     Set swApp = Application.SldWorks2 @/ o. M- ?( s8 S5 x% \0 F* ^
  10.     Set swDraw = swApp.ActiveDoc
    $ V; \) j8 B  m
  11.     Set swView = swDraw.GetFirstView! K) a0 ~+ m/ F! ~9 V- b
  12.     Do While Not swView Is Nothing
    : U" l0 E/ A4 B" d$ F
  13.         Set swTable = swView.GetFirstTableAnnotation: m5 Z9 p- _2 u# u9 l! v
  14.         Do While Not swTable Is Nothing
    ' N: H9 r  _9 O) A( d; o" |. S* _
  15.             nNumRow = swTable.RowCount '获取切割清单行数
    ) v# A& x3 \' {6 H, X
  16.             For i = 0 To nNumRow - 2
    ( V0 l( j6 c: e
  17.                 swTable.Text(i, 6) = "={2}D" & i + 1 & "*F" & i + 1 '写入总重方程式到切割清单( ], U2 a5 B2 |" B3 @. {4 ?
  18.             Next i
    5 Z' C* J5 `# y) s. ?% u
  19.             Set swTable = swTable.GetNext" y) }8 y$ m" f; ~4 Y  ?/ C1 y% r( s
  20.         Loop+ x: K1 l5 p& U; N
  21.         Set swView = swView.GetNextView% r& Z$ ^. F$ T( D+ H& e" W
  22.     Loop
    & \$ |3 B3 S5 d0 n. b; J
  23. End Sub. u# B6 e5 q: i! I6 [9 E0 n
复制代码
7 W* f9 f  k6 W0 I6 C4 k- ^
如果不愿意复制粘贴,那就下载这个吧: 工程图切割清单填写每行焊件总重.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
' R6 Q  e$ R0 [9 D8 s讚一個!舉一反三!謝謝樓主分享。
# M! w" b. k/ {5 T
感谢丹大的大力支持!
发表于 2016-3-15 13:08:47 | 显示全部楼层 来自: 中国广西桂林
很实用的工具,谢楼主!
发表于 2016-3-15 15:09:59 | 显示全部楼层 来自: 中国台湾
其實,樓主可以搜一下「常駐宏」及「特徵宏」,悶大都有很完整說明及教學2 g( O! Z* n- \0 ]3 O0 J3 D
一來無需在工程中圖再運行另一個宏來填寫方程,二來能徹底解決無法自動更新的問題。
 楼主| 发表于 2016-3-15 16:32:10 | 显示全部楼层 来自: 中国四川攀枝花
gt.adan 发表于 2016-3-15 15:096 [2 H' U5 s" n  A, E5 w9 m0 U- s
其實,樓主可以搜一下「常駐宏」及「特徵宏」,悶大都有很完整說明及教學
3 N7 s% e1 C7 d一來無需在工程中圖再運行另一個 ...

0 H; w+ u1 Y: ^+ A* c  k1 A2 H+ n本论坛里搜索不到『常驻宏』和『特征宏』的资料,到开思去找到了闷大的原帖:
* p, W" P$ f( A7 J9 ohttp://bbs.icax.org/thread-911488-1-2.html
2 R6 U3 ]7 I/ Z- L# Y: _感觉用常驻宏来更新比特征宏要好一些,闷大的常驻宏切换窗口就运行一下,这样就不用手动去更新总重了,真正做到了一劳永逸。
: |1 W3 I6 S5 o6 x非常感谢丹大的提示!
发表于 2016-4-20 17:18:49 | 显示全部楼层 来自: 中国辽宁大连
这个16的代码在12中运行出问题,提示如图
- t$ n) m, o: K& G7 z: A+ p) D% Z8 U 2.jpg 1.jpg + F) Q5 W1 b* b+ W
- k; u9 v6 j9 ~" ?7 U
发表于 2016-4-21 15:29:10 | 显示全部楼层 来自: 中国辽宁大连
hexiaohuihex 发表于 2016-4-20 17:181 Q/ ]0 X) w; p
这个16的代码在12中运行出问题,提示如图

$ T% R8 L# w9 t8 c& k已解决,是我自己拷贝代码的过程中一些乱码一同拷入,没删干净导致宏不认。
( R" ]! @2 M& t' t已正常运行,多谢楼主了
发表于 2016-4-21 20:21:19 | 显示全部楼层 来自: 中国山东
对于焊接切割清单计算总重的这个问题,闷大在别网有一个能彻底解决总重的问题,而且如果配合常驻宏还能一劳永逸,楼主研究的精神是好,但是如果想彻底解决这个问题,还是建议楼主去拜读闷大的,[总重宏],相信楼主会深有感触。
发表于 2016-4-21 21:05:02 | 显示全部楼层 来自: 中国安徽蚌埠
觉得好奇怪!) _. e) w+ \* ]
我在焊接件的模板属性制作时,先添加焊接->添加属性,如图 0421.png
- A* A, p5 R- p5 f/ e* p, P5 p5 G/ o& p
画好焊件
  j3 i* Z" Y4 ]" P! a9 W4 K+ p: r! i设置材料,子实体的属性自动出现
( w  ~9 |& \: c; W) M 04212.png / b3 `. V# I% y! q' B  \8 j
" f( _& P  K$ s0 E/ a0 }
看总重在文件属性- [% c0 P! K7 R7 _
04213.png
' r: P% [( P. [; b& k3 u! M& S
+ j( T' Q6 u# g1 u没有什么难度的啊
) [  X+ o! l4 \- C5 k具体效果
4 t/ X1 f& e+ g  h
. K' S. V# d8 s/ I& k 171433wvjx2uapsb4xj447.gif 0 J) C& L% a( M# I0 F
7 T1 e4 D  S9 w

  V( i1 {& _4 `6 b' E! p

评分

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

查看全部评分

发表于 2016-4-22 18:24:37 | 显示全部楼层 来自: 中国天津
jinqin11 发表于 2016-4-21 21:05
+ I+ N7 ]9 W/ M5 r) J7 c' b* D8 X% {觉得好奇怪!
/ S  Z  o+ _% J5 G9 |: b" v. D- b我在焊接件的模板属性制作时,先添加焊接->添加属性,如图

* p% _; U- S$ |3 O" c6 K8 y/ b材料明细表和焊件切割清单的区别在于,焊件切割清单可以直接提取焊件的轮廓属性(如果需要甚至还可以直接提取某一焊接件长度),比如说,“∠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运行出现如下情况:# D6 t$ m- k) X; O+ x

; a  V2 X4 O  |: ~6 m0 o
捕获.JPG
发表于 2018-3-9 16:29:36 | 显示全部楼层 来自: 中国湖南
这个完全是利用sw宏运行的,也没反应9 M; S3 d' C. U% H

% p, X% M7 c8 {7 L' Z
捕获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 )

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