乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 14|回复: 3

[编程交流] 仅分解嵌套块

[复制链接]

3

主题

9

帖子

6

银币

初来乍到

Rank: 1

铜币
15
发表于 2022-7-5 16:20:53 | 显示全部楼层 |阅读模式
你好
 
试图寻找类似主题所说的内容,但只找到了能爆炸一切的主题。我只想分解块内的块,然后保留放置的主块。
 
我有数百个街区,其中一些在一个街区内,所以自动的东西会很好
 
谢谢你的帮助
厘米
回复

使用道具 举报

4

主题

2143

帖子

2197

银币

限制会员

铜币
-24
发表于 2022-7-5 16:50:44 | 显示全部楼层
我已经将您的帖子转移到AutoLISP、Visual LISP和DCL论坛。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 17:17:10 | 显示全部楼层
请参见此处:
http://www.cadtutor.net/forum/showthread.php?72399-仅分解嵌套块&p=636640&viewfull=1#post636640
回复

使用道具 举报

66

主题

1552

帖子

1514

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
325
发表于 2022-7-5 17:30:57 | 显示全部楼层
 
不错,需要递归
我在尝试迭代方法时很开心:
 
  1. (defun C:test ( / o n L b)
  2. (defun Bdef->SubentsL ( nm / e L )
  3.    (setq e (cdr (assoc -2 (entget (tblobjname "BLOCK" nm)))))
  4.    (while e (setq L (cons e L)) (setq e (entnext e))) L
  5. )
  6. (and
  7.    (setq n (car (entsel "\nSelect block to "flatten": ")))
  8.    (setq n (vlax-ename->vla-object n))
  9.    (setq n (vla-get-EffectiveName n))
  10.    (progn
  11.      (while
  12.        (vl-some
  13.          (function
  14.            (lambda (x / o)
  15.              (and
  16.                (= "INSERT" (cdr (assoc 0 x)))
  17.                (setq L (cons (cdr (assoc 2 x)) L))
  18.                (setq o (vlax-ename->vla-object (cdr (assoc -1 x))))
  19.                (vlax-write-enabled-p o)
  20.                (not (vl-catch-all-error-p (vl-catch-all-apply 'vla-Explode (list o))))
  21.                (not (vla-Delete o))
  22.              )
  23.            )
  24.          )
  25.          (mapcar 'entget (Bdef->SubentsL n))
  26.        )
  27.      ); while
  28.      (and (= "Yes" (progn (initget "Yes No") (cond ((getkword "\nAttempt to purge the SubBlocks? [Yes/No] <Yes>: ")) ("Yes"))))
  29.        (setq b (vla-get-Blocks (vla-get-ActiveDocument (vlax-get-acad-object))))
  30.        (foreach x L (vl-catch-all-apply 'vla-Delete (list (vla-item b x))) )
  31.      ); and
  32.    ); progn
  33. ); and
  34. (princ)
  35. ); defun
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-14 18:29 , Processed in 1.675717 second(s), 60 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表