明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 954|回复: 2

[源码] 那个高手朋友能帮我看看吗?块的问题(高手在民间)

[复制链接]
发表于 2013-7-26 13:06 | 显示全部楼层 |阅读模式
1明经币
哪个高手帮忙看看,谢谢高手了。
例如:我想在进入图纸的时候 自动搜索 哪个块里面包含有文字 Tekla structures  ,搜索到后删除这个块.
请问问 有办法可以实现吗????急 谢谢高手了!  跪求!

 楼主| 发表于 2013-7-26 14:11 | 显示全部楼层
(defun c:scc ()
  (setvar "CMDECHO" 0)
  (setq ss (ssget '((0 . "INSERT"))))
  (foreach x (sstolst ss)
    (progn
      (setq ename-lst (blk-name-lst x))
      (if (vl-remove-if-not
            '(lambda (y) (= (dxf 1 (cadr y)) "Tekla structures"))
            ename-lst
          )
        (vla-delete (vlax-ename->vla-object x))
      )
    )
  )
  (prin1)
)
;;;选择集转图元名列表
(defun sstolst (ss)
  (vl-remove-if-not
    '(lambda (x) (equal (type x) 'ename))
    (mapcar 'cadr (ssnamex ss))
  )
)
;;; 取dxf组码
(defun dxf (g e)
  (cond
    ((= (type e) 'ename) (cdr (assoc g (entget e))))
    ((= (type e) 'list) (cdr (assoc g e)))
  )
)
;;;取无名快中对象名称图元名列表
(defun blk-name-lst (blk / enext entNames)
  (setq        enext
         (cdr
           (assoc
             -2
             (tblSearch
               "block"
               (dxf 2 (entget blk))
             )
           )
         )
  )
  (while enext
    (setq entNames
           (cons (list (dxf 0 (entget enext)) enext)
                 entNames
           )
    )
    (setq enext (entnext enext))
  )
  (reverse entNames)
)
回复

使用道具 举报

发表于 2013-7-26 14:18 | 显示全部楼层
好厉害,虽然看不太懂。学习下。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-9 05:24 , Processed in 0.197423 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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