选择集图元 引用
各位大侠,小弟菜鸟,刚接触vba,想实现个小功能:就是有大量的cad文本,我想均匀的删除其中的一部分,其中每四个点里面留下一个,故而我先用选择集选中所要文本,然后将选择集赋值给数组,通过数组删掉不要的文本,其中设置一个小循环,即图元号逢4保留,具体程序如下:
Sub errase()
Dim sset As AcadSelectionSet
Dim l As AcadText
Dim l1() As AcadText
Dim a As Long, b As Long
Dim filtertype(0) As Integer, filterdata(0) As Variant
'If Not IsNull(ThisDrawing.SelectionSets.Item("ss")) Then
' Set sset = ThisDrawing.SelectionSets.Item("ss")
' sset.Delete
'End If
filtertype(0) = 0
filterdata(0) = "text"
Set sset = ThisDrawing.SelectionSets.Add("ll")
sset.SelectOnScreen filtertype, filterdata
a = sset.Count - 1
b = a Mod 4
ReDim l1(a)
Dim k As Long
With sset
For Each l In sset
Set l1(k) = l
k = k + 1
Next
End With
Dim j As Long
For k = 0 To a
For j = 1 To b
If k <> 4 * j Then
l(k).Delete
End If
Next
Next
ss1.Delete
End Sub
cad图在附件里,因为原图太大,所以删了一些点,请各位大侠帮忙啊 不胜感激!
同志们,给点力啊 小弟急用! 再顶顶 期待大侠啊! 自己顶 来人啊?!
你这个是等高线标注太密了是不是?想放稀一些.隔一个删4个,受你选择的顺序影响,也许保留的不是你想要的.
我觉得你可以先在电子表格里用一个宏隔一行删除4行,再重新展点. VBALISPER 发表于 2012-4-4 22:06 static/image/common/back.gif
你这个是等高线标注太密了是不是?想放稀一些.隔一个删4个,受你选择的顺序影响,也许保留的不是你想要的.
我 ...
谢谢你的回复 是您说的意思,但是如果一整行的删,是不是把同样的高程都删了呢 同时大哥 这个宏我不会弄啊!能不能先按我的意思给我看看程序呢?非常感谢! 本帖最后由 VBALISPER 于 2012-4-5 23:24 编辑
是删除了高程.EXCEL表格的一行全删
Sub Macro1()
'
' Macro2 Macro
' 宏由 番茄花园 录制,时间: 2007-9-22
For a = 1611 To 1 Step -6 '从1611行开始倒着删除行,每隔一行删除5行;因为还要隔一行,所以这里步长是-6
Rows(a - 4 & ":" & a).Select '该数字到该数字-4之间刚好就是5行,这里先选中,下一行语句执行删除,并让下面的行自动上移
Selection.Delete Shift:=xlUp
Next a
End Sub
VBALISPER 发表于 2012-4-5 23:22 static/image/common/back.gif
是删除了高程.EXCEL表格的一行全删
Sub Macro1()
谢谢您的给力回答,因为 我原来的数据本来就在cad图里面,那现在还有提取出来了,那怎么将其提出来呢?请你帮帮我!其实我最想问的还是怎么引用选择集里面的图元?谢谢您!
页:
[1]