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() & }# V% m8 V4 I6 j$ Z; O$ d
Dim work As Workspace
/ }+ [9 v4 j; A. {( w# ]7 `Dim new As Database 9 b, o/ P& s1 O4 n" X; x9 P+ O
Dim elem As Object
- Z. x" O7 C- H+ R4 L3 ODim rs As Recordset
1 K9 M' G% S1 W# [- SDim RowNum As Integer
5 ?6 k  R+ X4 {+ i5 J9 o  a! QSet work = DBEngine.Workspaces(0)
/ w( ?$ J- Z/ Z3 |% g+ }9 @6 a, f9 VDim dbs As Database
3 \0 H6 @' Q3 yDim tdfNew As TableDef
1 a1 E3 n/ V* x# n0 X' iDim tdf As TableDef # z" [0 \1 @+ O+ [% Q  K
Dim dbsname As String
2 f- f8 {+ @1 |) f/ N' VDim array1 As Variant ( a* n: e6 M  g5 ^
Dim array2 As Variant ‘声明所需的变量及类型
. M% Q% a, h! X7 `; ndbsname = “D:\材料表.mdb”
+ R! L. q: a5 e* i1 C# ?) O‘声明Access数据库写到哪一个文件
6 K2 ~$ F1 U- M$ @% G9 n. ~On Error Resume Next
; n2 p, k5 O) x4 w  U# {Set dbs = work.CreateDatabase(dbsname, _ - D% g) ^: V2 Q2 \' n2 k; E
dbLangGeneral) $ R7 k! f0 J3 h- o0 b
If Err Then 7 S/ ]4 p5 ~: u- l. a5 ?( ~
Kill (dbsname)
0 X9 ~! U: _7 d5 ^- c‘发现要写入的Access数据库文件已存在就将其删除 6 q4 z& Z2 l* K( B( ]* E0 Z0 q
Set dbs = work.CreateDatabase(dbsname, _ , ~; P0 T2 e1 B; t: j
dbLangGeneral)
& K1 T1 ~8 G* }. k/ K( X3 ?# @6 S" YEnd If
% Y: m( o! y/ y- _Set tdfNew = dbs.CreateTableDef + K+ U8 R7 X% O9 T
(“电气 _材料明细表”)
& w6 Z3 Q8 \2 v$ k( ^  w‘建立一个名为电气材料明细表的表 . E# h# {1 n( ^! {9 k+ n
RowNum = 0
7 S* f6 N2 ^; {Dim Header As Boolean
1 Q" \: U- e* N, X+ DHeader = False
$ N8 p" j" C. x# {1 Q& yFor Each elem In ThisDrawing.ModelSpace
& h. A9 c. v  v. c' B‘在CAD模型空间,查找所有图形对象
! P0 E( j5 ?0 q' L6 }With elem , z$ K. K; B$ X5 Z# d, k
If StrComp(.EntityName,_ 7 q/ Z& y) C1 y. ^
“AcDbBlockReference”, 1) = 0 Then
& f; w2 ^. d$ q( [( f$ vIf .HasAttributes Then
& n1 B( _7 K6 Z1 harray1 = .GetAttributes
/ }6 ^& T( R$ k( Harray2 = .GetConstantAttributes
% E! G) Z- S- A# f! o‘设置array1指向图形对象的属性 $ f( ^$ I" Z, y# B# \8 y# \) s
‘设置array2指向图形对象的固定属性
: ]( f, v7 b$ s+ X. {For Count = LBound(array2) To _
; [; Y3 O" |7 p; N! VUBound(array2) 1 S0 R1 z2 }; w7 {9 [5 \
If Header = False Then ) y- m, |7 [$ }. R+ n
If StrComp(array2(Count).EntityName, _
: v. z  ^* f# A1 M# m# d! i“AcDbAttributeDefinition”, 1) = 0 Then
: C" G& G( l0 d* Y! _$ l9 stdfNew.Fields.AppendtdfNew._
1 Q; ?! r( L1 D9 v% ~# x5 l1 X" \CreateField(array2(Count).TagString, dbText)
& y  b0 o# \" M9 t" z7 s, Q# H! XEnd If
6 ?5 W4 e/ S/ B‘读出属性值读出,作为Access数据库表的标题
; q/ t8 b8 ]% h8 Q* h6 [  q1 I0 pEnd If
. e2 T. k5 e5 O$ Z: r0 _' R% {Next Count
- b1 T! ]- y2 I- ^  ^% x; TFor Count = LBound(array1) To _
9 G) c+ j2 }4 B5 }* cUBound(array1) / J* D# ^$ y- w
If Header = False Then   }5 o5 S" Y4 \6 t: T5 `( v
If StrComp(array1(Count).EntityName, _
, @. I2 P' W, Z5 m7 N$ O“AcDbAttribute”, 1) = 0 Then # J( W! r1 ~" }/ S
tdfNew.Fields.Append tdfNew. _ 8 Q- \6 t3 b& E% D* Q
CreateField(array1(Count).TagString, dbText)   H1 t( K1 x6 p
End If 8 G% p! {/ m2 X4 K6 |+ k! o/ B5 t
End If
3 I& s" k, Y4 j$ hNext Count
3 o. c, F* s$ {If Header = False Then 0 k+ l+ j4 Y8 N6 i5 b7 H
dbs.TableDefs.Append tdfNew
8 r7 T$ _. F! r. c% OSet rs = dbs.OpenRecordset 8 f% Q; y2 C+ Q( f( s
(“电气材料 _明细表”, dbOpenTable) ‘打开记录 $ b) `9 w! ?8 f3 g+ D* Q% j" S. p
End If
$ G$ R5 E- T! l+ f+ W( MRowNum = RowNum + 1
7 k9 \6 y4 s5 H4 A  f9 P; Zrs.AddNew ‘增加一笔新记录
' I+ E& s# r# S# NFor Count = LBound(array2) _
  Q8 E, y- m5 cTo UBound(array2) : {6 S7 d6 y8 e
rs(Count).Value = array2(Count).TextString
% q0 Y" e. b- S4 ]/ ENext Count ‘读固定属性值 ( Y4 v* C2 A  U) Q; D! ?
For Count = LBound(array1) To _
* _: T# p. @( u% C2 }$ U8 E* tUBound(array1)
6 l& ~% g, l  B5 e  @rs(UBound(array2) + Count + 1).Value = _ / d3 n2 E- Z& a
array1(Count).TextString * A" c/ P  r* O4 e) K- |
Next Count ‘读输入属性值 : t1 Z9 z% p$ k) C0 ~
rs.Update ‘增加新记录修改结束
3 c0 M. c/ y  B8 W) tHeader = True
0 ^; y! M& d2 F+ WEnd If 3 y' W- m; j; Q0 z  m& u
End If 3 C+ D) F: W" w& b8 S
End With
! T% Y& c8 D% Y, ~1 `8 v" P( CNext elem
5 V- y9 @( |  |' X2 v5 _rs. Close ‘关闭记录,释放资源
8 G3 [6 W) s% b' N$ \) I0 Kdbs.Close ‘关闭数据库,释放资源 : e+ h+ C' I2 O6 u" o  u
End Sub
发表于 2009-1-6 13:50 | 显示全部楼层
赚钱中
发表于 2009-1-6 21:17 | 显示全部楼层
thank a lot- q+ F% Y& k9 x. {
真是太好了
$ n, J, }" _- X5 J* b6 p這就是我要的 ^^
发表于 2010-5-11 23:13 | 显示全部楼层
好用吗?有谁下载了?
发表于 2010-8-24 19:08 | 显示全部楼层
学习学习!
发表于 2010-10-25 14:37 | 显示全部楼层
先看看看再说
发表于 2011-2-21 05:48 | 显示全部楼层
下来看看先,谢谢了。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2026-1-28 05:04

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

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

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