QQ登录

只需一步,快速开始

登录 | 注册 | 找回密码

三维网

 找回密码
 注册

QQ登录

只需一步,快速开始

展开

通知     

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

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

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

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

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

x
本帖最后由 pzhzshun 于 2016-3-15 16:32 编辑
8 t, b4 M' U8 o$ |( D
  }. j) g5 x- I  前段时间,在这个贴子里:http://www.3dportal.cn/discuz/forum.php?mod=redirect&goto=findpost&ptid=1253110&pid=8713151&fromuid=73388根据丹大的帮助,学会了用宏把切割清单里每个零件的总重写入到属性中。解决了手工填写每行焊件总重的问题。
/ h( z/ I6 U8 u1 T" c' x  用了一段时间,感觉这种写入总重的方式还是有些不妥的地方:修改了焊件的尺寸后,每次都要运行宏把总重写入属性里。如果忘记运行宏,那么工程图中切割清单里每行的总重就是错误的。
. w7 n7 a8 g: v  o' n5 a+ \  为避免每次修改焊件尺寸都要运行宏写入总重的弊端,就考虑用宏把每行总重的计算公式,直接写在工程图切割清单,总重的那一单元格中。$ i. j) b- M/ h, Q* E
  用我可怜的 E 文知识,在 API 帮助里查询了许久,终于找到了工程图切割清单中填写内容的代码。/ R* y( Y, C8 E6 P( G6 _% o9 ]
  独乐乐不如众乐乐,这里把代码分享一下:0 V# C& t- b7 t/ a5 y/ g
  1. Option Explicit
    $ m3 n* W0 K0 e+ t
  2. Dim swApp As SldWorks.SldWorks) ?: W3 K. T/ E1 n: a
  3. Dim swDraw As SldWorks.DrawingDoc
    & k2 N8 B9 J0 g2 D% Z  t) C$ T: h% b
  4. Dim swView As SldWorks.View; F0 G7 A" L% I- |) T+ q( x4 b1 b
  5. Dim swTable As SldWorks.TableAnnotation) f7 f" R, |6 ^. ]0 G" _$ V
  6. Dim nNumRow As Long8 o2 Y7 _: c7 H* @
  7. Dim i As Long
    . p& g0 M. c5 ]* s
  8. Sub main()
    $ o, t) [4 D  [" }1 R& q
  9.     Set swApp = Application.SldWorks
    6 r2 E/ j3 p# F4 s# Y+ @# t
  10.     Set swDraw = swApp.ActiveDoc
    ! Y0 @- M. b: z  M2 P& }1 u: P
  11.     Set swView = swDraw.GetFirstView
    + Y: Z, Q$ P& A- @" }: n
  12.     Do While Not swView Is Nothing# g, z. X0 ^9 `- T  u- s8 a
  13.         Set swTable = swView.GetFirstTableAnnotation% Z5 u( }! L2 \" \- W+ t- Y
  14.         Do While Not swTable Is Nothing
    6 T9 _9 q* B& m+ G- N( ]  B
  15.             nNumRow = swTable.RowCount '获取切割清单行数' m9 T* C! j4 Z3 K" U- E
  16.             For i = 0 To nNumRow - 25 J! u: ~7 @: O- `! o; G
  17.                 swTable.Text(i, 6) = "={2}D" & i + 1 & "*F" & i + 1 '写入总重方程式到切割清单
    ( S. S$ Q- |. Y( B5 G5 o" W
  18.             Next i
    * ]$ A0 j* Q2 [) P$ |
  19.             Set swTable = swTable.GetNext
    ' f, e+ z$ {3 P% T# s
  20.         Loop
    ; C& z3 ~4 n9 h6 z& B
  21.         Set swView = swView.GetNextView4 r$ A  s3 p* o) m) \
  22.     Loop2 P$ Z* g4 l; a6 }
  23. End Sub
    ; ~  \- x+ a+ ?7 |4 m
复制代码

1 p3 s( R' e6 j如果不愿意复制粘贴,那就下载这个吧: 工程图切割清单填写每行焊件总重.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/ E: p' D9 E6 s7 o4 P
讚一個!舉一反三!謝謝樓主分享。

( j* z3 c. y# ~* x- @+ z+ D感谢丹大的大力支持!
发表于 2016-3-15 13:08:47 | 显示全部楼层 来自: 中国广西桂林
很实用的工具,谢楼主!
发表于 2016-3-15 15:09:59 | 显示全部楼层 来自: 中国台湾
其實,樓主可以搜一下「常駐宏」及「特徵宏」,悶大都有很完整說明及教學
1 u5 y/ f' W% [" N0 k, n% G6 e3 f一來無需在工程中圖再運行另一個宏來填寫方程,二來能徹底解決無法自動更新的問題。
 楼主| 发表于 2016-3-15 16:32:10 | 显示全部楼层 来自: 中国四川攀枝花
gt.adan 发表于 2016-3-15 15:091 A! F1 J; D5 \' @; x
其實,樓主可以搜一下「常駐宏」及「特徵宏」,悶大都有很完整說明及教學- q0 N5 `: x! Q0 u- T
一來無需在工程中圖再運行另一個 ...
. x: G  q; h* w3 k0 e4 g8 a7 t
本论坛里搜索不到『常驻宏』和『特征宏』的资料,到开思去找到了闷大的原帖:8 ?) `  l1 B& {# y) @  `2 Y
http://bbs.icax.org/thread-911488-1-2.html4 j% `. v, v2 u
感觉用常驻宏来更新比特征宏要好一些,闷大的常驻宏切换窗口就运行一下,这样就不用手动去更新总重了,真正做到了一劳永逸。% q5 T& T' `. R% }% u
非常感谢丹大的提示!
发表于 2016-4-20 17:18:49 | 显示全部楼层 来自: 中国辽宁大连
这个16的代码在12中运行出问题,提示如图8 k- ~' N$ c2 H4 s' o+ E
2.jpg 1.jpg
& U7 ?" o0 e; w% a4 [
" r2 o* Q9 ~& Y" Z1 n% [
发表于 2016-4-21 15:29:10 | 显示全部楼层 来自: 中国辽宁大连
hexiaohuihex 发表于 2016-4-20 17:186 J' |$ C, U" ?) z- u
这个16的代码在12中运行出问题,提示如图

. b1 {! ^" f  A! }; \" ^, H# |4 G已解决,是我自己拷贝代码的过程中一些乱码一同拷入,没删干净导致宏不认。" H: v2 F0 ?* A$ q/ L1 U: U% V
已正常运行,多谢楼主了
发表于 2016-4-21 20:21:19 | 显示全部楼层 来自: 中国山东
对于焊接切割清单计算总重的这个问题,闷大在别网有一个能彻底解决总重的问题,而且如果配合常驻宏还能一劳永逸,楼主研究的精神是好,但是如果想彻底解决这个问题,还是建议楼主去拜读闷大的,[总重宏],相信楼主会深有感触。
发表于 2016-4-21 21:05:02 | 显示全部楼层 来自: 中国安徽蚌埠
觉得好奇怪!5 o" n6 l8 ], _9 Y8 T% {# X+ E
我在焊接件的模板属性制作时,先添加焊接->添加属性,如图 0421.png
" Z* \' Y3 D$ s5 d  }
) j4 X4 u) P( @9 q画好焊件* r  x- a7 T9 U6 s- X: w
设置材料,子实体的属性自动出现
# \& h* s- r9 v( {* R$ L 04212.png ; v4 \# y, e( J
2 c2 j$ t: W$ P% r1 B. N% c  r. H& P/ b6 I
看总重在文件属性' X1 L- |4 Z3 j4 h0 Z6 p  ?
04213.png
4 j5 w8 z5 K6 T: S; ^1 L
- W8 e" O( |; h8 A1 r没有什么难度的啊
* G: s, {* I/ q0 X3 U9 I3 \( |. g  r1 y具体效果
6 E$ g5 c/ q- t, O' P& u/ J' |2 ], S, n5 m- s$ C8 K
171433wvjx2uapsb4xj447.gif
, [" P9 J  O5 s& e+ W* W" N0 K5 w& P

0 X: p. B) _+ P; `4 b

评分

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

查看全部评分

发表于 2016-4-22 18:24:37 | 显示全部楼层 来自: 中国天津
jinqin11 发表于 2016-4-21 21:05! m* A& y" L* f6 p6 y; T- J! Q5 c
觉得好奇怪!
- b" \" n. r0 _' H. B4 M我在焊接件的模板属性制作时,先添加焊接->添加属性,如图
+ H6 N( C) I( o$ @/ P3 u
材料明细表和焊件切割清单的区别在于,焊件切割清单可以直接提取焊件的轮廓属性(如果需要甚至还可以直接提取某一焊接件长度),比如说,“∠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运行出现如下情况:
; H- {' \3 p& @! }; n8 F, G' c. {, z2 X9 s. v+ \1 W7 V
捕获.JPG
发表于 2018-3-9 16:29:36 | 显示全部楼层 来自: 中国湖南
这个完全是利用sw宏运行的,也没反应, J: b/ F+ s+ D( H+ y& a
8 m4 x( y7 V" w
捕获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 )

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