机械社区

 找回密码
 注册会员

QQ登录

只需一步,快速开始

搜索
查看: 4437|回复: 5

分享两个宏,有详细注解,可尽情修改使用,代码也一起放了。

[复制链接]
发表于 2021-1-13 14:11:47 | 显示全部楼层 |阅读模式
, k8 H1 ]4 d5 r+ j5 f
工程图转格式:
" A; }: Q. q4 f# q# w; h1 m
% ^8 R7 a; L/ l, T: [. x" z  P) H9 z( V6 B: d
Dim swApp As Object9 J- c4 M1 Z2 a' N) m9 {. t
Dim Part As Object
% `) B7 k2 K5 KDim Filename As String4 b* L1 |/ R4 }* J
Dim No As Integer
( g' H) p# f) j/ `" QDim Title As String          '以上设定变量
2 J" d1 d! N+ K$ A% LSub main()6 M+ F$ y3 F  t( J' e
Set swApp = Application.SldWorks
, e  T" B! `" k9 t  T9 [Set Part = swApp.ActiveDoc                                                  '以上交换数据
$ o( j3 E. T# VFilename = Part.GetPathName()                                               'Filename为文件名
7 E2 k0 H( ^7 T. rNo = Len(Filename)                                                          'no为工程图文件名字符串总数
6 T+ `! M* S0 LIf No > 0 Then                                                              '当NO大于0时(转换格式名称是工程图名称,故要先保存工程图才可转换,工程图未保存无名称,无字符串,不可进行一下步)
6 v/ d1 |. h" g, J, h. ^2 E! sFilename = Left(Filename, No - 7) + "." + Right(Filename, 1)                '字串符操作,no-7为去掉工程图后缀名,"."+ right(filename,1)为增加后缀名最后一个字母作为识别,用于区别客户来图,可不要
+ X  k( x# Q) i9 U7 [- p7 QPart.SaveAs2 Filename & ".dwg", 0, True, False                              '输出需要转换的格式文件,已有文件则自动替换,不提示,(有些格式文件在打开状态中不可替换,替换不成功也不提示)
& v: ~$ O& c/ C7 t/ ?0 l# V/ M$ ePart.SaveAs2 Filename & ".pdf", 0, True, False7 |9 c* c. Z0 S* ?
End If: O' x2 H# n+ h' \7 ^
End Sub
5 y0 I: N* z: j3 l, Z# N+ [. |" @) T- G* O6 h

# F4 m* V& F2 V# D% B4 W2 ^5 z% j3 {- u" S% Y! {
属性改写宏:
6 E3 s  N2 l1 K
7 U+ C& `7 y6 U% }! X" H& g
: B/ C' o, O1 ?) R: Z& a
1 E* S4 P; T+ kSub main()
7 W: m2 W7 A. U. N# n& f% ~; i* T6 \& ^. K' z: T8 `
Dim swApp As SldWorks.SldWorks' _9 C  x7 O6 J2 B/ u0 j
Dim swModel2 As SldWorks.ModelDoc2
! n/ s6 v, m3 h( z- O' bDim SelMgr As SldWorks.SelectionMgr  O" f0 r, W* L" K3 O6 C/ L
Dim vCustInfoNameArr2 As Variant
7 D/ k6 i' Q7 n' d* b6 e' G/ b( e  dDim vCustInfoName2 As Variant2 V3 Y+ ]  X! h
Dim CurCFGname As Variant! c. p, Z5 j. ?  n. a7 E& n, e) O
Dim CurCFGnameCount As Integer# a  R& T3 a( r8 H. T  x/ U
Dim Vnamearr As Variant/ r0 x/ L1 F1 \2 L5 ]  B; W
Dim CusPropMgr As CustomPropertyManager
. g6 A- [5 W3 Y9 [$ zDim bRet As Boolean: S' a" \7 c2 c
Dim Vnamearr2 As Variant! u8 N% E' w; b8 B
* A3 B/ _. S# F8 @
Dim strmat As String# I, I" L2 L) x! F# L
Dim tempvalue As String  ?" k1 ?) G) E6 f% L
# j& `: Z$ x2 O+ E: X/ M  a3 [& e& G
Set swApp = Application.SldWorks7 C. A8 x% o5 I. g. ~$ d" k
Set swModel2 = swApp.ActiveDoc) k, @' ^& e4 k& v7 p) A+ B% a
Set SelMgr = swModel2.SelectionManager '
  Y& G) I1 _8 [" w
% U( t6 g) g1 _( V: A+ IDim tg1 As String
$ m; e7 W$ U3 w0 M6 hDim tg2 As String7 c( b: }$ r& x8 q8 {
Dim tg3 As String4 J3 r, X, W  j1 S5 U' |
Dim tg4 As String
  B6 ^. B( w7 @% Q. HDim tg5 As String7 x. H$ H; \6 h7 s: r
Dim tg6 As String
5 N* w% [( O9 s( A2 mDim tg7 As String7 N, B  N8 ?4 c1 a1 B7 ^, P0 U: P- q
Dim tg8 As String
0 @. W% Q$ N3 r5 m, E& q  ^3 b% ^Dim tg9 As String
% ?7 ^+ {$ W6 [$ w# ]9 xDim tg10 As String1 A4 c9 V; ~" N: p( Y
Dim tg11 As String
: t3 E. w' u- N* s8 TDim wm As String
1 \5 Y1 H) I+ j, S" Q' kDim wm1 As Integer, ~0 `4 v9 B1 I! L2 k
Dim wm2 As String* |; i0 v- L0 c3 `# J1 W4 E
Dim wm3 As String. j. o& W2 o2 X) ]
Dim wm4 As String5 t; N) c* y/ ?) C7 _
Dim wm5 As String
7 y+ |; F9 N2 Y8 |& K* `9 i& sDim wm6 As String
! D7 ~& \  T% X" @6 Q" }( nDim wm7 As Integer2 v! f. E. `; W, t6 Z0 E
Dim wm8 As String# Y+ n5 v. v$ j+ J; M. x
Dim wm9 As Integer8 Z# n2 w5 C) N+ D/ Z8 g2 m0 W
Dim lz As String
" V5 p5 ]0 r. w$ K5 D( c) nDim lz1 As Integer) X. b: B5 G& ~$ Q7 o* ~1 f
Dim lz2 As String& ~  t  O' ]( t7 W4 v- W) [0 Q
Dim lz3 As String
' w$ a6 _) f* e+ a% L8 kDim lz4 As Integer' K9 h6 U% S& i( e- T
Dim lz5 As Integer6 K5 K: k5 V3 P: a% G! x
Dim lz6 As String
6 r# _" @; b" V2 ?5 P* ]4 ADim lz7 As Integer                                                                     '以上为设定变量
$ D( D0 q3 `  w5 Z0 I. x) h) y

7 q0 X' `1 S, ~! y! x: {5 G- rswApp.ActiveDoc.ActiveView.FrameState = 1
0 ^( b0 J' x$ k; V4 }vCustInfoNameArr2 = swModel2.GetCustomInfoNames
& E1 E2 P( T& v1 ^  If Not IsEmpty(vCustInfoNameArr2) Then
% Q" B( v. u  ?6 z/ O  P     For Each vCustInfoName2 In vCustInfoNameArr23 B- B5 J( _( n7 @. M) e4 i
         bRet = swModel2.DeleteCustomInfo(vCustInfoName2)( F( P" d9 `( v. f# Q* |# o
      Next
7 X6 D. ?0 o# _5 K, ]1 O  End If                                                                               '此段是删除自定属性中的所有项和其项值# ]0 U( P! p" |4 i$ y& d5 r

. ^3 z( `: N9 c) s0 K! N( M$ O3 U' Q1 P' K2 X) s' v9 l
CurCFGname = swModel2.GetConfigurationNames
  P4 o$ [" e" H! XCurCFGnameCount = swModel2.GetConfigurationCount
" n0 g$ _! K/ }% s& VFor i = 0 To CurCFGnameCount - 1( ^( c  c) O: D" ^& h) W
    Set CusPropMgr = swModel2.Extension.CustomPropertyManager(CurCFGname(i))2 z+ L$ {$ A! ^! j) O2 J( J
    Vnamearr = CusPropMgr.GetNames
* t: c5 X' t8 S    If Not IsEmpty(Vnamearr) Then
  G& a- d. _( I        For Each Vnamearr2 In Vnamearr0 w2 j" B6 k+ H3 y: A; r
            bRet = swModel2.DeleteCustomInfo2(CurCFGname(i), Vnamearr2)% }/ N' L" k: U6 _- z2 v) ~
        Next
" ?$ A% n6 ]% g; w, H7 C/ \( B    End If7 t9 Z! r1 @, |8 I; G1 L
    Next                                                                               '此断是删除其他配置中的属性所有项和其项值0 J4 M8 ]5 I$ \# g
7 ?8 C# A5 u5 H1 y; _
" A7 x& S7 P9 f
wm = swApp.ActiveDoc.GetTitle()                                                         '定义是文件名: \: ^. p& H* z; r
lz = swApp.ActiveDoc.GetPathName()                                                      '定义为文件路径
% X: v: }, t( \tg6 = Chr(34) + Trim("SW-Material" + "@") + wm + Chr(34)                                '定义材料属性
0 t* m$ Z: H4 g- {tg7 = Chr(34) + Trim("厚度" + "@") + wm + Chr(34)                                       '定义钣金厚度属性6 m3 l+ s9 W2 g
tg8 = Chr(34) + Trim("SW-Mass" + "@") + wm + Chr(34) + "kg"                             '定义质量属性
+ X- `. ]% j% `) Z/ F& qtg9 = Chr(34) + Trim("SW-SurfaceArea" + "@") + wm + Chr(34) + "㎡"                      '定义表面积属性. V: x- p) f8 e" T, o
bRet = swModel2.DeleteCustomInfo2("", "图号"). }+ s; d; t$ }% ^- Y, P
bRet = swModel2.DeleteCustomInfo2("", "Description")
1 u! Q/ t0 I+ U0 }7 g! K" F7 i* Z' C8 C! @

9 v7 M- O# V3 o2 B; vwm1 = InStrRev(wm, " ") - 1                                                              '引号内为空格,为图名分离符号        '从右向左搜索到第一个" "符号为第几个字串符
( ~; x1 a+ Q4 wIf wm1 > 0 Then                                                                          '当mw1大于0量时
7 c1 s: x! Y6 e2 P. m' s# F    wm2 = Left(wm, wm1)                                                                  'wm2等于从wm的左侧开始提取mw1个字符3 W4 b, q; p; @, h, e6 _
    wm3 = Left(LTrim(wm), 3)                                                             'wm等于wm去除左侧无效字符的左前三个字符
6 y4 e: W% l- g: M    If wm3 = "GBT" Then                                                                  '当wm3等于"GBT"时1 ?) J/ \5 D' i/ M
        wm4 = "GB/T" + Mid(wm2, 4)                                                       'wm4等于"GB/T"和wm2的第4个和后面的所有字符              '当零件是国标时添加国标号,文件名中/是非法字符
2 @3 [: `8 x  }8 O7 v3 L    Else$ x6 j9 G- ^! l
        wm4 = wm2                                                                         '否则wm4等wm2           '空格前面是图号) h! c. {7 b) {; |1 \9 e) d
    End If" v4 s# x( y. _  C$ M% O

5 [2 y) Z0 z- g, a    wm5 = Mid(wm, wm1 + 2)                                                                'wm5等于wm中的第wm1+2个后面的所有字符
6 d- Q) f$ n: d) f. |, t8 t' M$ B    wm6 = Right(wm, 7)                                                                    'wm6等于wm最后面的7个字符
$ d/ ]) R. T- q    If wm6 = ".SLDPRT" Or wm6 = ".SLDASM" Or wm6 = ".sldprt" Or wm6 = ".sldasm" Then      '当wm6等于这4个值时
+ Q1 U+ s; t  i; Y* P$ J        wm7 = Len(wm5) - 7                                                                'wm7等于wm5的所有字符数-78 g3 c* t1 y% d% i: e
    Else
# q. q9 F- Y+ W  }5 }6 J/ _: ~        wm7 = Len(wm5)                                                                    '否则wm7等于wm5的所有字符数8 K0 G  K, b  _% x; ]
    End If$ q+ J. K) L- x' h
    tg5 = Left(wm5, wm7)                                                                  'tg5等于wm5左侧的wm7个字符          ,空格后面是名称,有后缀名并去掉后缀名,无后缀后(文件未保存时)直接上档
/ n8 f: d7 o5 r6 \) j" Z3 [) i- J; F# r- s6 I
End If                                                                                                                       '此段为图名分离定义
: @7 E- f6 A9 j) `3 ~. L- M9 {0 t/ T3 w4 V, k( a! l2 i, h" A
* o5 A' g3 \6 e
If wm1 > 0 Then                                                                           '当wm1大于0时4 _# G# A! w! n; q! r3 j
tg4 = wm4                                                                                 'tg4等于wm4              '文件名有空格时,图号为分离出来图号# P  }" o1 ^9 {! |+ ~- J
Else
' R$ B6 c, a" }; R! I5 |7 l    wm8 = Right(wm, 7)                                                                    'wm8等于wm最后面的7个字符
. S( h+ D5 ]$ S5 a) P3 Q6 B    If wm8 = ".SLDPRT" Or wm8 = ".SLDASM" Or wm8 = ".sldprt" Or wm8 = ".sldasm" Then      '当wm8等于这4个值时
; k+ U2 {& b6 P6 N6 }3 V        wm9 = Len(wm) - 7                                                                 'wm9等于wm的所有字符数-7$ p/ z  n. }, v* f
    Else5 u5 R% e8 u  l' ^
        wm9 = Len(wm)
6 _$ `/ X0 z9 `2 e0 r    End If                                                                                '否则wm9等于wm所有字符数-72 ~- Z8 V: l& U6 z1 E
tg4 = Left(wm, wm9)                                                                       'tg4等于wm左侧的wm9个字符    '文件无空格时,文件名即是图号,并去掉后缀名,无后缀名(文件未保存时)直接上档
4 O: H; U3 D8 ^End If                                                                                                                        '此段为非图号名称命名文件,将文件名加到图号属性
% b$ G. t! d6 ]+ g- G6 @* B: O'例,fgq01-001 前门板:分离后图号(fgq-001),名称(前门板)8 J7 ^. x7 V+ p; I2 j
'例,fgq01-001 前 门板:分离后图号(fgq-001 前),名称(门板)4 P. g9 y8 P+ z& o' o, l
'例,fgq01-001-前门板:分离后图号(fgq-001-前门板),名称为空! \! U/ l4 X: v
'以最后一个空格为准分离
7 r" @/ ~0 i9 @
: W9 M/ f2 j6 X$ P+ f' M2 U! k3 r/ P4 U
lz1 = InStrRev(lz, "--")                                                                 'lz1为lz由后向前搜索到第一个"--"字符在第几个0 i) q6 p# @+ g0 g
If lz1 > 0 Then                                                                          '当lz1大于0时/ w7 W5 g2 a6 B, v
lz2 = Mid(lz, lz1 - 8, 8)                                                                'lz2等于lz的第lz1-8个和其后面8个字符! h2 _8 f/ W5 w# f1 n; j& Y! x) y
lz3 = Mid(lz, lz1 + 2)                                                                   'lz3等于lz的第lz2+2个后其后面所有字符
6 U! Y7 x, g8 o& \lz4 = InStrRev(lz2, "\")                                                                 'lz4为lz2由后向前搜索到第一个"\"字符在第几个8 K. Y$ R: P$ i- p2 b9 X" e0 j
lz5 = InStr(lz3, "\")                                                                    'lz5为lz2由前向后搜索到第一个"\"字符在第几个& p/ _/ V  |. n& _4 _; c
tg1 = Mid(lz2, lz4 + 1)                                                                  'tg1等于lz2的第lz4+1个后面的所有字符+ F5 Z9 P# P  F  s  H6 t7 z4 w5 t
'tg1 = Right(lz2, 8 - lz4)                                                               'tg1等于lz2右侧的8-lz4个字符(lz2总字符为8个)  u* G" O- ~8 Z% u  `# }- I& r
tg2 = Left(lz3, lz5 - 1)                                                                 'tg2等于lz3左侧的lz5-1个字符2 p4 O* r- c! a
' k6 p4 A" q+ ?  l  i' I$ w' d
lz6 = Mid(lz3, lz5 + 1)                                                                  'lz6等于lz3第lz5+1个后面的所有字符. n$ z2 A" h3 o! j3 ^
lz7 = InStr(lz6, "\")                                                                    'lz7为lz6由左向右搜索出第一个"\"字符在第几个# m: ?) a/ [5 ^( ]& P2 T* v* t
If lz7 > 0 Then                                                                          '当lz7大于0时
0 r# V# C  u8 Atg3 = Left(lz6, lz7 - 1)                                                                 'tg3等于lz6左侧的lz7-1个字符& R8 i4 R0 u9 K4 k+ V# a' a
End If
4 L9 O" w) g# E$ c2 o5 `+ u1 {End If                                                                                    '此段为文件路径提取项目号
* h5 R/ W2 a6 g* F'例,零件文件完整路径为:E:\工作文档\B-非标产品\非标--F类\FGQ--定制角架\2020版\前门板.SLDPRT. f" f. y4 U% J, C
'由后向前搜索“--”,第一个“--”向前到“\”间为产品编号(FGQ),向后到“\”间为产品名称(定制角架),向后的第一个“\”和第二个间“\”,为版本号(2020版)。
9 p- M+ L5 k- i! t6 g5 Y& D+ R- l/ P) c2 \7 g
- V2 b7 F9 i" C( q6 u6 D5 e) g

6 V! [1 }9 q, ]& N- i2 t6 l0 fbRet = swModel2.AddCustomInfo3("", "产品编号", swCustomInfoText, tg1)
3 b5 @) }% h" IbRet = swModel2.AddCustomInfo3("", "产品名称", swCustomInfoText, tg2)2 i* T/ ]9 K6 E3 s) U& F8 f+ n5 R
bRet = swModel2.AddCustomInfo3("", "版本号", swCustomInfoText, tg3)
9 I; o7 c7 H% h' U. gbRet = swModel2.AddCustomInfo3("", "图号", swCustomInfoText, tg4)3 F, r4 a8 n* F
bRet = swModel2.AddCustomInfo3("", "Description", swCustomInfoText, tg5)
& B# }2 j  W! z1 xbRet = swModel2.AddCustomInfo3("", "数量", swCustomInfoText, "1")5 m% c% i7 K) _
bRet = swModel2.AddCustomInfo3("", "备注1", swCustomInfoText, " ")+ i/ V( c5 e8 m" Y
bRet = swModel2.AddCustomInfo3("", "备注2", swCustomInfoText, " "), s4 X( w+ D0 M/ j2 W
bRet = swModel2.AddCustomInfo3("", "备注3", swCustomInfoText, " ")
/ F7 o9 s  |0 {1 s. u, n; e' U( IbRet = swModel2.AddCustomInfo3("", "Material", swCustomInfoText, tg6)
* |# `- ]' h. |# b' MbRet = swModel2.AddCustomInfo3("", "SH", swCustomInfoText, tg7)
$ Y9 D; ?( T7 K) B6 p# tbRet = swModel2.AddCustomInfo3("", "重量", swCustomInfoText, tg8)
( C+ P+ q5 F" zbRet = swModel2.AddCustomInfo3("", "表面积", swCustomInfoText, tg9)                         '此段为填写自定义属性项与其值/ @3 L) R1 R2 i, A" e- n% b+ \

0 n; O' f  U  f; GDim thisFeat As SldWorks.Feature                                                         '另外增加一段宏,取读取切割清单数据,并添加到属性项。6 B$ F. t& ]* |2 X& Y
Dim thisSubFeat As SldWorks.Feature
) w5 \; C0 N0 L/ ^' xDim cutFolder As Object6 O7 E/ ]* W3 h- u2 {( Z
Dim BodyCount As Integer
, K% r4 f2 }! \( `( S9 X0 U, a) R7 B5 wDim custPropMgr As SldWorks.CustomPropertyManager
. l7 o; W; U* [+ Q, B4 U- V$ eDim propNames As Variant7 B, i% J' c! F9 {9 a& p
Dim vName As Variant
5 L3 a7 I4 l) o; g0 c7 r, d! K5 HDim propName As String) u5 W# u+ z, {/ G8 K
Dim Value As String1 q+ k: S: o! a& O3 n9 p
Dim resolvedValue As String
: b* B/ T3 t+ t- P! @Dim bjkcd As Double& s* O' G; J* G0 Y. W5 R
Dim bjkkd As Double: b( J! @9 z9 J; S; J
'Sub main()
0 G  a- Y- w. `& j9 \- B0 |4 R7 W; O'Set swApp = Application.SldWorks7 B  G0 _2 Q3 Q# @0 p4 T- y
Set Part = swApp.ActiveDoc
5 T( r) V- }( T, X% BSet thisFeat = Part.FirstFeature; o& t: C% O, J3 q+ n8 s: }7 X
Do While Not thisFeat Is Nothing '遍历设计树
. f/ \9 S% n3 k. w; yIf thisFeat.GetTypeName = "SolidBodyFolder" Then, Y! z# s1 O0 v2 L
thisFeat.GetSpecificFeature2.UpdateCutList
5 |( O1 R( I" n5 pEnd If
$ ~8 l: V2 O" {( Y$ v) L5 FSet thisSubFeat = thisFeat.GetFirstSubFeature
5 e: X& B/ a% g0 s% h8 DDo While Not thisSubFeat Is Nothing
6 {9 t( u5 U" X6 \If thisSubFeat.GetTypeName = "CutListFolder" Then '查找切割清单
2 D6 f) ~3 f3 n7 F3 a* \& @0 XSet cutFolder = thisSubFeat.GetSpecificFeature2; _7 a$ v$ Y6 u7 r" u9 Y
End If
; w* e' o# Q! NIf Not cutFolder Is Nothing Then1 t3 L: p0 w  v" ^  T9 A, P2 ]6 t
BodyCount = cutFolder.GetBodyCount! w7 Q- E8 V; D$ v1 n# ~: o, v
If BodyCount > 0 Then
2 b* A6 V" q9 x% c. oSet custPropMgr = thisSubFeat.CustomPropertyManager
* N* \8 ], F( f- F+ k% b# PIf Not custPropMgr Is Nothing Then
) q" g- l  J- q* a% n' UpropNames = custPropMgr.GetNames '获取切割清单属性的数据全部名称并放入数组' d0 v. {1 b9 P- j
If Not IsEmpty(propNames) Then
" q& h0 m  B, ^# D) n, d% BFor Each vName In propNames. H9 \" x7 S" ^* }3 [& ^9 z
propName = vName5 [% Q& e3 a* F" J
custPropMgr.Get2 propName, Value, resolvedValue '获取全部属性名称 ,数值和评估的值# [1 Q0 u7 m! _! X: i
If propName = "边界框长度" Then bjkcd = resolvedValue '判断是否是自己所需要的数据,如果是就获取
6 \4 Q& Y0 }! ]# M0 s1 o* qIf propName = "边界框宽度" Then bjkkd = resolvedValue; V  M: @6 i2 {
Next vName$ U5 S  r% e+ J7 F8 {' H4 i# P
End If( e& ]3 M( D1 }
End If: D. P. A& y0 q/ Q0 t
End If
' u8 T5 b9 O  h8 ?End If
+ c/ i9 m! Z% t5 P8 gSet thisSubFeat = thisSubFeat.GetNextSubFeature- F) }1 s' Y! `; u/ X% I8 e
Loop$ a: f8 p1 R$ [% ?
Set thisFeat = thisFeat.GetNextFeature
- Z9 y: A8 V$ ?+ {: O' d; `( ALoop9 t3 V: a9 @2 L" M: b$ M& v, ?4 W
'blnretval = Part.DeleteCustomInfo2("", "边界框长度") '删除属性栏上摘要信息的数据6 B% x0 L7 X3 b" m$ c5 q0 Y
'blnretval = Part.DeleteCustomInfo2("", "边界框宽度")
4 ]' R; n  V* h" t/ d6 y( eblnretval = Part.AddCustomInfo3("", "开料长度", swCustomInfoText, bjkcd) '添加数据到摘要信息; s* A2 _! g7 i- \! a
blnretval = Part.AddCustomInfo3("", "开料宽度", swCustomInfoText, bjkkd)' w# u; v# s8 F7 u0 n6 v1 ^. b! {

  }- m, F0 E, G& F2 r+ ~* sEnd Sub, }6 N" E/ _1 s4 r
8 l  b% h8 [8 b" g. T* w) {* W) C5 \

本帖子中包含更多资源

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

x
回复

使用道具 举报

发表于 2021-1-13 16:28:08 | 显示全部楼层
挺复杂啊,比较难用吧??
回复 支持 反对

使用道具 举报

发表于 2021-1-13 17:17:50 | 显示全部楼层
这个是不是CAD转pdf的?佩服做软件二次开发的人。
回复 支持 反对

使用道具 举报

发表于 2021-1-13 17:29:04 | 显示全部楼层
学习一下。
回复

使用道具 举报

 楼主| 发表于 2021-1-13 17:40:43 | 显示全部楼层
晓昀 发表于 2021-1-13 17:179 Z/ |& @6 e- Z
这个是不是CAD转pdf的?佩服做软件二次开发的人。
  a- s, E" y0 F, t3 x- b
cad转PDF,用cad的PDF打印机就行了,这个是sw转dwg,dxf,和pdf等格式的。, J- D( D7 ~+ M" B% _

点评

大牛!  发表于 2021-1-13 18:01
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

小黑屋|手机版|Archiver|机械社区 ( 京ICP备10217105号-1,京ICP证050210号,浙公网安备33038202004372号 )

GMT+8, 2025-2-27 18:00 , Processed in 0.067597 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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