找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1064|回复: 2

[LISP程序]:擴展GETSEL.LSP(E/T)

[复制链接]

已领礼包: 2个

财富等级: 恭喜发财

发表于 2007-12-20 09:05:00 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
http://www.xdcad.net/forum/showthread.php?s=&threadid=645719

  1.   [FONT=courier new]
  2. (defun test (lay typ / filter lay-len laynamelst n ss ss-filter sslen ss-lst
  3.                  typ-len typnamelst typss-filter typss-lst
  4.             )
  5.   (p-s '("cmdecho" 0
  6.         "expert" 0
  7.        ) t
  8.   )
  9.   (sssetfirst nil nil)
  10.   (if (null lay)
  11.     (if (= "" (setq lay (getstring "\n请输入层名或回车选择目标层实体:")))
  12.       (progn
  13.         (princ "\n请选择目标层实体:")
  14.         (setq ss-lst (th-ss2lst (ssget))
  15.               laynamelst (acad_strlsort (th1-lst-delsame (mapcar
  16.                                                            (function
  17.                                                                      (lambda
  18.                                                                        (x)
  19.                                                                        (txt-get-dxf 8 x)
  20.                                                                      )
  21.                                                            )
  22.                                                            ss-lst
  23.                                                          )
  24.                                         )
  25.                          )
  26.               lay-len (length laynamelst)
  27.               n 0
  28.               lay (apply
  29.                     'strcat
  30.                     (mapcar
  31.                       (function (lambda (x)
  32.                                   (setq n (1+ n))
  33.                                   (if (= n lay-len)
  34.                                     x
  35.                                     (strcat x ",")
  36.                                   )
  37.                                 )
  38.                       )
  39.                       laynamelst
  40.                     )
  41.                   )
  42.               ss-filter (list (cons 8 lay))
  43.         )
  44.       )
  45.       (setq ss-filter (list (cons 8 (strcase lay))))
  46.     )
  47.     (setq ss-filter (list (cons 8 (strcase lay))))
  48.   )
  49.   (if (null typ)
  50.     (if (= "" (setq typ (getstring "\n请输入筛选类型或回车选择目标类型实体:")))
  51.       (progn
  52.         (princ "\n请选择目标类型实体:")
  53.         (setq typss-lst (th-ss2lst (ssget))
  54.               typnamelst (acad_strlsort (th1-lst-delsame (mapcar
  55.                                                            (function
  56.                                                                      (lambda
  57.                                                                        (x)
  58.                                                                        (txt-get-dxf 0 x)
  59.                                                                      )
  60.                                                            )
  61.                                                            typss-lst
  62.                                                          )
  63.                                         )
  64.                          )
  65.               typ-len (length typnamelst)
  66.               n 0
  67.               typ (apply
  68.                     'strcat
  69.                     (mapcar
  70.                       (function (lambda (x)
  71.                                   (setq n (1+ n))
  72.                                   (if (= n typ-len)
  73.                                     x
  74.                                     (strcat x ",")
  75.                                   )
  76.                                 )
  77.                       )
  78.                       typnamelst
  79.                     )
  80.                   )
  81.               typss-filter (list (cons 0 typ))
  82.         )
  83.       )
  84.       (setq typss-filter (list (cons 0 (strcase typ))))
  85.     )
  86.     (setq typss-filter (list (cons 0 (strcase typ))))
  87.   )
  88.   (setq filter (append
  89.                  ss-filter
  90.                  typss-filter
  91.                )
  92.   )
  93.   (setq ss (setq ss (ssget "_X" filter))
  94.         sslen (sslength ss)
  95.   )
  96.   (prompt (th-str-format "\n收集層$2#上的所有$1#實體..." (list typ lay)))
  97.   (prompt (th-str-format "\n$1#個實體已經加入到當前選擇集." (list
  98.                                                                   (itoa sslen)
  99.                                                             )
  100.           )
  101.   )
  102.   (p-e)
  103.   ss
  104. )

  105.   [/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2007-12-20 18:39:44 | 显示全部楼层
跟过滤选择有什么 不同吗
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

 楼主| 发表于 2007-12-21 08:02:54 | 显示全部楼层
就是过滤选择
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-11-16 23:38 , Processed in 0.319862 second(s), 36 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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