找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1288|回复: 3

[LISP函数]:從選擇集刪除特定特性的實體

[复制链接]

已领礼包: 2个

财富等级: 恭喜发财

发表于 2007-12-26 13:57:31 | 显示全部楼层 |阅读模式

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

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

×

  1.   [FONT=courier new]
  2. ;;;參考[url]http://intervision.hjem.wanadoo.dk/[/url]
  3. (defun th-ssdel-prop-and (sset proplst / ent i ss)
  4.   (setq i -1
  5.         ss (ssadd)
  6.   )
  7.   (setq proplst (mapcar
  8.                   (function (lambda (x)
  9.                               (cons (car x) (strcase (cdr x)))
  10.                             )
  11.                   )
  12.                   proplst
  13.                 )
  14.   )
  15.   (repeat (sslength sset)
  16.     (setq ent (ssname sset (setq i (1+ i))))
  17.     (if (eval (cons 'or (mapcar
  18.                           (function (lambda (x)
  19.                                       (not (member x (entget ent)))
  20.                                     )
  21.                           )
  22.                           proplst
  23.                         )
  24.               )
  25.         )
  26.       (ssadd ent ss)
  27.     )
  28.   )
  29.   ss
  30. )
  31. ;;; e.g. to remove all circles on layer pipe from sset1
  32. ;;; (th-ssdel-prop-and sset1 '((0 . "circle")(8 . "pipe")))
  33. (defun th-ssdel-prop-or (sset proplst / ent i ss)
  34.   (setq i -1
  35.         ss (ssadd)
  36.   )
  37.   (setq proplst (mapcar
  38.                   (function (lambda (x)
  39.                               (cons (car x) (strcase (cdr x)))
  40.                             )
  41.                   )
  42.                   proplst
  43.                 )
  44.   )
  45.   (repeat (sslength sset)
  46.     (setq ent (ssname sset (setq i (1+ i))))
  47.     (if (eval (cons 'and (mapcar
  48.                            (function (lambda (x)
  49.                                        (not (member x (entget ent)))
  50.                                      )
  51.                            )
  52.                            proplst
  53.                          )
  54.               )
  55.         )
  56.       (ssadd ent ss)
  57.     )
  58.   )
  59.   ss
  60. )
  61. ;;; e.g. to remove all circles or all entities on layer pipe from sset1
  62. ;;; (th-ssdel-prop-or '((0 . "circle")(8 . "pipe")))
  63. ;;;1.點對第二位不分大小寫
  64. ;;;2.沒有改變SSET1(如果用SSDEL,則會改變SSET),而是新建選擇集SS.

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

  1. (setq ss (ssget "P" '((0 . "circle")(8 . "pipe"))))
  2. (command ".select" ss1 "r" ss "")
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

 楼主| 发表于 2008-1-2 11:17:42 | 显示全部楼层
http://www.xdcad.net/forum/showt ... 3243924#post3243924

  1.   [FONT=courier new]
  2. (defun tt-ssdel-prop-and (sset proplst / ss1 ss2)
  3.   (setq proplst (mapcar
  4.                   (function (lambda (x)
  5.                               (cons (car x) (strcase (cdr x)))
  6.                             )
  7.                   )
  8.                   proplst
  9.                 )
  10.   )
  11.   (command "_.select" sset "")
  12.   (setq ss1 (ssget "p")
  13.         ss2 (ssget "P" proplst)
  14.   )
  15.   (txt-ssdiff ss1 ss2)
  16. )
  17. (defun tt-ssdel-prop-or (sset proplst / ssn  ss1)
  18.   (setq proplst (mapcar
  19.                   (function (lambda (x)
  20.                               (cons (car x) (strcase (cdr x)))
  21.                             )
  22.                   )
  23.                   proplst
  24.                 )
  25.   )
  26.   (setq ss1 sset)
  27.   (mapcar
  28.     (function (lambda (x)
  29.                 (command "_.select" sset "")
  30.                 (setq ssn (ssget "p" (list x)))
  31.                 (setq ss1 (txt-ssdiff ss1 ssn))
  32.               )
  33.     )
  34.     proplst
  35.   )
  36.   ss1
  37. )
  38.   [/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 07:05 , Processed in 0.172822 second(s), 38 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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