明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 961|回复: 4

未定义类型 错误,无法运行vba

[复制链接]
发表于 2013-11-5 15:42 | 显示全部楼层 |阅读模式
http://bbs.mjtd.com/thread-96754-1-1.html
提取块属性的代码:
  • Sub aa()
  • Dim bobj As AcadBlockReference
  • Dim a
  • Dim arr()
  • Dim ss As AcadSelectionSet
  • Dim filtertype(0 To 0) As Integer
  • Dim filterdata(0 To 0) As Variant
  • Dim xls As Excel.Application
  • Set xls = New Excel.Application
  • Set ss = ThisDrawing.SelectionSets.Add(CStr(Rnd))
  • filtertype(0) = 0
  • filterdata(0) = "insert"
  • ss.SelectOnScreen filtertype, filterdata
  • For Each bobj In ss
  • i = i + 1
  • ReDim Preserve arr(1 To i)
  • a = bobj.GetAttributes
  • arr(i) = a(0).TextString
  • Next
  • With xls.Workbooks.Add
  •    .Sheets(1).[a1].Resize(i, 1) = xls.Transpose(arr)
  •    .SaveAs "d:/123.xls"
  •    .Close
  • End With
  • xls.Quit
  • End Sub
    为什么我使用代码运行会出现这样的错误呢




本帖子中包含更多资源

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

x
发表于 2013-11-6 16:10 | 显示全部楼层
打开VBA IDE工具-引用,在引用里面勾选“Microsoft Excel  14.0  Object  Library”。(注:如果你安装的EXCEL为2010;其他版本类似)
 楼主| 发表于 2013-11-6 18:30 | 显示全部楼层
wylong 发表于 2013-11-6 16:10
打开VBA IDE工具-引用,在引用里面勾选“Microsoft Excel  14.0  Object  Library”。(注:如果你安装的EXC ...

谢谢你的回复, 我装的是07版excel 引用以后,代码可以运行了,但是出现这个,是怎么回事?

本帖子中包含更多资源

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

x
 楼主| 发表于 2013-11-6 18:34 | 显示全部楼层
wylong 发表于 2013-11-6 16:10
打开VBA IDE工具-引用,在引用里面勾选“Microsoft Excel  14.0  Object  Library”。(注:如果你安装的EXC ...

我把代码中得xls  改成  xlsx 以后就变成这样,实在不知道问题在哪儿,,,,

本帖子中包含更多资源

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

x
发表于 2013-11-7 12:09 | 显示全部楼层
  1. 错误提示的是命名选择集已存在。
  2. 问题在此句:Set ss = ThisDrawing.SelectionSets.Add(CStr(Rnd))

  3. 建议改为这样:Set ss = CreateSelectionSet

  4. CreateSelectionSet函数定义如下:
  5. '返回一个空选择集
  6. Public Function CreateSelectionSet(Optional SelectionSetName As String = "mjtd") As AcadSelectionSet
  7.     On Error Resume Next
  8.     ThisDrawing.SelectionSets(SelectionSetName).Delete
  9.     Set CreateSelectionSet = ThisDrawing.SelectionSets.Add(SelectionSetName)
  10.     On Error GoTo 0
  11. End Function
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-5-20 00:44 , Processed in 0.195543 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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