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() ; @; {7 ~2 n) z# T
Dim work As Workspace ( Q$ z5 I5 k7 r3 b$ A% `# q1 p' k
Dim new As Database
! h# t5 j# l8 N. e0 Q# k% yDim elem As Object
8 [$ w6 q* H2 q$ GDim rs As Recordset
( p4 Y7 m. r+ c) D& S' S( a- WDim RowNum As Integer ( z+ ?3 N2 a* v+ q6 }
Set work = DBEngine.Workspaces(0) - w0 I6 n+ P/ S) _+ q8 h1 f- O
Dim dbs As Database # @# C9 s7 M* |
Dim tdfNew As TableDef * a6 [- M3 h8 O" L! ^1 M
Dim tdf As TableDef
& L  n4 V# I4 W1 B4 r/ v, [Dim dbsname As String
& P1 B* A6 M  D3 |Dim array1 As Variant
1 v7 I; j) L! i9 \Dim array2 As Variant ‘声明所需的变量及类型 8 Q. a0 |0 W, ^' b7 J) T
dbsname = “D:\材料表.mdb”
5 m  R0 A' B9 [  c0 q( T‘声明Access数据库写到哪一个文件
# t5 I/ ^; P4 ?: J; t. B# COn Error Resume Next
! t4 U% E8 |8 p# I$ vSet dbs = work.CreateDatabase(dbsname, _ 2 F4 L( A* i7 i# S) A
dbLangGeneral)
) {; S% Q( I" H$ U: h* |, V* [) B; f5 aIf Err Then
# Q' U; f" z' C1 d1 D, g( X/ ZKill (dbsname) ; i5 |. s" k! F% J
‘发现要写入的Access数据库文件已存在就将其删除
- x% e2 K4 l1 N: {8 _' R# i  ~9 xSet dbs = work.CreateDatabase(dbsname, _
! `' h+ S8 H2 f8 K1 GdbLangGeneral)
. n9 I0 j+ |" A% q3 P& P2 sEnd If
( z( I! d& t% _Set tdfNew = dbs.CreateTableDef
8 L  B6 ~' n2 Z: h) d5 B2 r(“电气 _材料明细表”) : v+ ^: D* G7 ~3 t+ E
‘建立一个名为电气材料明细表的表
! x( V( C0 Q( l& ^- R( S- T# bRowNum = 0 ! M. K& G1 k8 d* z4 p' I
Dim Header As Boolean
7 U" J$ g  x5 v5 h/ tHeader = False ( J% B2 P( O/ `# f' u
For Each elem In ThisDrawing.ModelSpace $ N7 l" @9 {8 e) ^$ u5 V' O0 i0 W% w
‘在CAD模型空间,查找所有图形对象 6 C& \% H% V; m2 O0 m4 |! J
With elem
( n) R* l6 J1 AIf StrComp(.EntityName,_ 5 l' ]" L  O# d0 r, l0 N8 R
“AcDbBlockReference”, 1) = 0 Then " Y; j8 [8 |" F9 f& q6 V
If .HasAttributes Then
8 `' @. |1 h. X' P& W( G* y  Y3 `array1 = .GetAttributes 0 a1 e8 m/ y$ s
array2 = .GetConstantAttributes ! m3 `+ w8 {/ I
‘设置array1指向图形对象的属性
' g" N2 ?. x+ m) m3 I: E‘设置array2指向图形对象的固定属性 9 l2 e) @' `( |1 ]! b1 \
For Count = LBound(array2) To _ ( i7 N9 L# U- _. n: i* u
UBound(array2)
0 A( w( }# H2 ], q. ~If Header = False Then
, J. ^" U: q. L1 u9 f! kIf StrComp(array2(Count).EntityName, _ ) u! v  [7 X& q  ?
“AcDbAttributeDefinition”, 1) = 0 Then
: y  V; [6 B0 j# g# w; f. AtdfNew.Fields.AppendtdfNew._
1 N9 ]3 y1 ]6 y5 V0 _# T. Z) ]# NCreateField(array2(Count).TagString, dbText)
4 a( Q! Y) x0 IEnd If : T5 L$ _- S- V' G  a  }* @3 M
‘读出属性值读出,作为Access数据库表的标题 & E3 J# ^5 _- l: ~1 j
End If + C* g; S% B( C3 c% i$ X( g
Next Count 1 @% g" ]& i. t! K- Q. \
For Count = LBound(array1) To _ " K1 J2 Z+ d" k5 j
UBound(array1) " g/ }  p& ]6 Y! f4 P6 B9 n# F
If Header = False Then
* z0 Q; m: ?. W8 bIf StrComp(array1(Count).EntityName, _
) O# h$ Q  `- B6 \% Z+ p. ^$ u; @7 G“AcDbAttribute”, 1) = 0 Then
: Y/ V  u2 P9 k, HtdfNew.Fields.Append tdfNew. _ " u2 J% @: B. \/ d5 x5 S* S
CreateField(array1(Count).TagString, dbText) - i1 v$ B" t3 ]9 j
End If
' `& A/ p" t0 k9 \% Q' @* c( `9 UEnd If 2 U& }( s, r6 G* H) i
Next Count 9 w/ s$ i1 Z% p! L- i& X% v
If Header = False Then
7 X# e( Z% \, b, s4 o+ y+ u7 Z4 hdbs.TableDefs.Append tdfNew 9 K0 n9 D- I' q4 v
Set rs = dbs.OpenRecordset
+ O0 \, K0 {& n% C3 t6 ?(“电气材料 _明细表”, dbOpenTable) ‘打开记录 2 C' [. u) k1 S, c" D) x
End If
5 e0 Z* I( K5 g9 V3 }2 gRowNum = RowNum + 1 5 n: c. n4 a7 y* V9 o/ H
rs.AddNew ‘增加一笔新记录 6 E1 Q* s4 F! @1 v) B! L* @
For Count = LBound(array2) _
/ U2 G. S* N/ U; H5 STo UBound(array2)
# g1 Y3 Z& r" `' ~' b+ Irs(Count).Value = array2(Count).TextString
; P# K+ a! u& ]. ~2 K0 Z& d, j5 I) hNext Count ‘读固定属性值 ) s3 B# ]" e, r/ a
For Count = LBound(array1) To _
. F$ J: S/ `* B6 K% uUBound(array1) + }3 W4 F( n2 i
rs(UBound(array2) + Count + 1).Value = _
- @' G/ U% ~  p; `4 u' Q( Garray1(Count).TextString
( z5 T( K. l: S1 {1 m7 G4 y9 zNext Count ‘读输入属性值
' o4 ^% s. Q1 k1 d' N* Ors.Update ‘增加新记录修改结束
  Q0 [! A" Y8 z2 ]Header = True
9 [0 E  f9 o9 k1 r' ~4 Y) aEnd If
8 E  |: l5 L/ N! h$ D$ cEnd If
$ _8 v& Z0 d! y5 E! fEnd With
/ @! q0 L: j& k2 a' NNext elem
1 T1 D! Y7 a) ^5 J" Prs. Close ‘关闭记录,释放资源 ( {( t  g# B6 K8 |% c
dbs.Close ‘关闭数据库,释放资源
/ f& s/ Q6 X/ W; P4 `2 y" fEnd Sub
发表于 2009-1-6 13:50 | 显示全部楼层
赚钱中
发表于 2009-1-6 21:17 | 显示全部楼层
thank a lot  |8 x; H2 ^0 h) k3 R+ y9 B: R
真是太好了 . v8 C2 a  C: O) D0 K' q
這就是我要的 ^^
发表于 2010-5-11 23:13 | 显示全部楼层
好用吗?有谁下载了?
发表于 2010-8-24 19:08 | 显示全部楼层
学习学习!
发表于 2010-10-25 14:37 | 显示全部楼层
先看看看再说
发表于 2011-2-21 05:48 | 显示全部楼层
下来看看先,谢谢了。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2026-2-10 01:12

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

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

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