明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2242|回复: 3

请高手帮忙实现这个功能!

[复制链接]
发表于 2004-11-3 21:04:00 | 显示全部楼层 |阅读模式
想实现的功能:获得一个模型空间上的所有实体的名称,相同实体的名称只显示一次。也就是统计一下实体的名称(没有重复的)


先谢谢!!
发表于 2004-11-5 09:41:00 | 显示全部楼层
请先明确一下什么叫相同的实体?
发表于 2004-11-5 10:15:00 | 显示全部楼层
  1. (defun c:test (/ ss i ents name names item)
  2.    (setq ss (ssget "x"))
  3.    (setq i 0)
  4.    (if ss
  5.        (progn
  6.            (repeat (sslength ss)
  7.   (setq ents (entget (ssname ss i)))
  8.   (setq name (cdr (assoc 0 ents)))
  9.   (if (setq item (assoc name names))
  10.      (setq names (subst (cons name (+ (cdr item) 1)) item names))
  11.      (setq names (append names (list (cons name 1))))
  12.   )
  13.   (setq i (1+ i))
  14.            )
  15.            (mapcar '(lambda (x)
  16.      (princ "\n")
  17.      (princ (car x))
  18.      (repeat (- 15 (strlen (car x))) (princ "-"))
  19.      (princ (cdr x))
  20.                )
  21.              names
  22.            )
  23.            (textscr)
  24.        )
  25.        (princ "没有对象!")
  26.    )
  27.    (princ)
  28. )
 楼主| 发表于 2004-11-9 12:30:00 | 显示全部楼层
谢谢了楼上的两位!这个功能我已经实现了。在VBA中


sub sss()


dim selset as acadselectset


dim sss as new collection


dim i as integer


for i= 0 to thisdrawing.modelspace.count-1


                                 sss add thisdrawing.modelspace.item(i).objectname, thisdrawing.modelspace.item(i).objectname


next i


end sub


现在又遇到一个问题是下面的:


       





请高手指点一下在VBA中要实现图片中类似的功能该怎么办?VBA中的combobox控件可以实现么??


先谢谢了!!

本帖子中包含更多资源

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

x
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-4-11 08:46 , Processed in 0.145179 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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