CAD设计论坛

 找回密码
 立即注册
论坛新手常用操作帮助系统等待验证的用户请看获取社区币方法的说明新注册会员必读(必修)
12
返回列表 发新帖
楼主: gysheng

cad统计材料表

[复制链接]
发表于 2008-10-17 16:08 | 显示全部楼层
下载不了了????
发表于 2008-10-17 16:10 | 显示全部楼层
怎么下载啊,为什么下不了?
发表于 2008-10-20 15:19 | 显示全部楼层
不知道是做什么用的
发表于 2008-12-10 13:25 | 显示全部楼层

顶起

请用过的同志说明一下怎么用
发表于 2009-1-6 13:04 | 显示全部楼层
Sub list() " ?& j; L; b! k' P
Dim work As Workspace & k& R) o2 Y* o6 [) n  d
Dim new As Database 0 R8 Y& X9 h. l4 d6 H. I
Dim elem As Object
  ?% }, W. z+ \1 f4 ^4 uDim rs As Recordset
1 T: q, G5 t, u" [* UDim RowNum As Integer   X0 n1 J' ~* T$ d* n
Set work = DBEngine.Workspaces(0)
! a8 Q. K0 g* [3 R, }- zDim dbs As Database
( J/ n- C3 a9 V3 V9 lDim tdfNew As TableDef & j' M# w* E  q* T' k
Dim tdf As TableDef 4 I' I: q9 @) r
Dim dbsname As String / f: |" x" r  I6 J
Dim array1 As Variant
. p( |. }) b& R, X) S7 V) zDim array2 As Variant ‘声明所需的变量及类型
0 a4 |( G& C9 }$ R2 rdbsname = “D:\材料表.mdb”
' w/ D. M# B' y; Y) Y% |0 Y% f‘声明Access数据库写到哪一个文件 : s3 y6 ^* t4 Y/ o( x1 P# `: `9 t
On Error Resume Next
, _! E3 g7 M/ o  |7 H8 V4 QSet dbs = work.CreateDatabase(dbsname, _
4 R+ D: `2 i/ S/ B8 r$ F* r% VdbLangGeneral) 3 W1 E% T- ]6 L- j3 C9 g: d* T$ H
If Err Then
0 i- d$ W& M3 o2 [# N1 RKill (dbsname) # S1 i. f) p; t1 l2 p8 ^% h
‘发现要写入的Access数据库文件已存在就将其删除
. N5 v+ E( i! [" `Set dbs = work.CreateDatabase(dbsname, _
/ f9 n+ y( c  l2 D& F* m$ RdbLangGeneral)
, l  V$ g% ~+ A1 HEnd If
, Z7 A5 G1 U% E9 x- }" Q  |5 bSet tdfNew = dbs.CreateTableDef 8 u0 ?6 Z% d$ L- _5 B8 _" Y9 k0 }5 h$ p- Z
(“电气 _材料明细表”) ' O; y. D4 [* S' A7 }
‘建立一个名为电气材料明细表的表 % [/ L0 X" J6 s! _( W# I$ i
RowNum = 0
) o( L$ v5 ^+ `0 E) l, M, R  sDim Header As Boolean
$ I% {: x1 U1 ]! |) }3 S4 e  UHeader = False
  u6 o0 T2 \& G7 `; i8 k' aFor Each elem In ThisDrawing.ModelSpace
# [, z- e2 N, s8 }' P‘在CAD模型空间,查找所有图形对象 1 C( y3 k& e4 H' F
With elem 8 S  z/ S  ]+ q8 o# q
If StrComp(.EntityName,_ 5 s' h. h, [+ L7 B2 e
“AcDbBlockReference”, 1) = 0 Then ! [, f, Y2 g+ I. I( X7 B, G4 z
If .HasAttributes Then   {* t1 j6 a! O( b
array1 = .GetAttributes
  s' |# Q* T7 }% barray2 = .GetConstantAttributes
/ s7 f7 [& S/ L; y7 [2 G2 {6 k7 n; s$ w‘设置array1指向图形对象的属性
3 r; C2 v/ A7 v7 x/ J) b‘设置array2指向图形对象的固定属性 * B7 |! q( e0 p. \* N0 I
For Count = LBound(array2) To _
0 r& @5 m& R  M- P! m. HUBound(array2)
" P1 F& S% W( t" i, o5 C+ d7 }If Header = False Then $ Z. {; y  V/ ?% w7 _: Q
If StrComp(array2(Count).EntityName, _
( G2 Q  c; M. ~5 _* D% E( @* q“AcDbAttributeDefinition”, 1) = 0 Then
! E) A: X2 H: p& BtdfNew.Fields.AppendtdfNew._ ! c6 @& h) N, ?: k1 y) W9 w
CreateField(array2(Count).TagString, dbText) 5 W- G8 V+ n6 r  o& P( E: B
End If
# v( F; }) v( r+ p. O. k0 k‘读出属性值读出,作为Access数据库表的标题 9 C" H; T& l( [4 [5 S" B
End If
& \- n4 G) A9 S' D9 Y$ M! F4 a4 a7 XNext Count
4 F8 \0 f2 r) ^" J$ n2 s) LFor Count = LBound(array1) To _ . p* r( o2 A8 {
UBound(array1)
, l2 x3 L; g, Q& lIf Header = False Then
8 }' p! z; p8 OIf StrComp(array1(Count).EntityName, _ 1 O8 h. i2 e* p# F- l! R
“AcDbAttribute”, 1) = 0 Then
; O6 X9 {' P  w$ ]tdfNew.Fields.Append tdfNew. _
  o8 a* S' s4 |: f- |9 T5 c  dCreateField(array1(Count).TagString, dbText) 4 N  ?9 j. I+ j$ x
End If ( r9 {/ B+ N4 u. ~- P" Y
End If
- d( f2 p9 B* ^Next Count . Y/ m8 w' t; _9 R
If Header = False Then $ f2 y$ m( @$ _6 N+ e  R; u
dbs.TableDefs.Append tdfNew 5 D; N5 q( ~$ A* I
Set rs = dbs.OpenRecordset : g4 ]" h) W, m$ t, h* T
(“电气材料 _明细表”, dbOpenTable) ‘打开记录
% t7 Y* Q! S' Z" v8 `End If
; X/ l3 i: R! f! N; F* CRowNum = RowNum + 1 ( U" x4 j$ j: {& D6 F: a# l3 M
rs.AddNew ‘增加一笔新记录 7 i1 ~9 q" V: c  ~* U  ?7 ]1 S2 w4 z
For Count = LBound(array2) _ 5 j7 V! Q8 e/ _8 `
To UBound(array2)
" x1 O! D/ ~1 g( @! urs(Count).Value = array2(Count).TextString / [4 m# h8 e$ F1 @
Next Count ‘读固定属性值
4 D; X% ^$ t: s& @* @* Q1 FFor Count = LBound(array1) To _ 2 b7 \. W1 j! R7 D* Y- |
UBound(array1) 8 r8 o/ a  T3 K6 y* N9 u# Q3 {; l
rs(UBound(array2) + Count + 1).Value = _ ' H" }) W9 K. K0 L/ T; D4 g/ K1 h/ G
array1(Count).TextString
( x7 m$ p: I9 J, k1 RNext Count ‘读输入属性值
- Q! k# `! U7 C; _0 o& j4 @+ Y/ ^rs.Update ‘增加新记录修改结束 6 K  \7 W/ G3 |2 q) ]
Header = True 1 ]+ D# b) C1 E4 n% T  j
End If
' Z0 W3 l. F: ^6 G7 o& Q+ S  R: Y! M1 _End If
% j) u" ]+ v9 }$ ]* v7 {End With , `* G* f) O9 }$ `, C
Next elem
! y6 ?0 a! }  ~' brs. Close ‘关闭记录,释放资源
, f' Y, _6 a: Ydbs.Close ‘关闭数据库,释放资源 ! p# s# g/ f, C" d
End Sub
发表于 2009-1-6 13:50 | 显示全部楼层
赚钱中
发表于 2009-1-6 21:17 | 显示全部楼层
thank a lot: X5 X6 \! C# ?+ g* ?, H- D& t7 ^% C
真是太好了 * `1 y  q2 h0 L. |+ b
這就是我要的 ^^
发表于 2010-5-11 23:13 | 显示全部楼层
好用吗?有谁下载了?
发表于 2010-8-24 19:08 | 显示全部楼层
学习学习!
发表于 2010-10-25 14:37 | 显示全部楼层
先看看看再说
发表于 2011-2-21 05:48 | 显示全部楼层
下来看看先,谢谢了。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关于|免责|隐私|版权|广告|联系|手机版|CAD设计论坛

GMT+8, 2025-11-20 07:32

CAD设计论坛,为工程师增加动力。

© 2005-2025 askcad.com. All rights reserved.

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