找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1118|回复: 1

[每日一码] 每个层单独保存DWG文件

[复制链接]

已领礼包: 19个

财富等级: 恭喜发财

发表于 2016-12-13 17:38:20 | 显示全部楼层 |阅读模式

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

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

×
;; Layers to Drawings  -  Lee Mac  -  2011  -  [url]www.lee-mac.com[/url]
;; WBlocks objects on each layer in a drawing to separate drawing files.

(defun c:lay2dwg ( / _UniqueFilename acdoc acsel fpath typevar )

    (defun _UniqueFilename ( seed / f i )
        (setq i 1)
        (if (findfile (setq f (strcat seed ".dwg")))
            (while (findfile (setq f (strcat seed "(" (itoa (setq i (1+ i))) ").dwg"))))
        )
        f
    )

    (defun _UniqueItem ( collection seed / i )
        (setq i 1)
        (while
            (null
                (vl-catch-all-error-p
                    (vl-catch-all-apply 'vla-item
                        (list collection (strcat seed (itoa (setq i (1+ i)))))
                    )
                )
            )
        )
        (strcat seed (itoa i))
    )

    (setq acdoc (vla-get-activedocument (vlax-get-acad-object))
          acsel (vla-get-selectionsets acdoc)
          acsel (vla-add acsel (_UniqueItem acsel "lay2dwg"))
          fpath (strcat (getvar 'DWGPREFIX) (cadr (fnsplitl (getvar 'DWGNAME))) "_")
    )
    (vla-clear acsel)
    (setq typevar
        (vlax-make-variant
             (vlax-safearray-fill
                 (vlax-make-safearray vlax-vbinteger '(0 . 1)) '(8 410)
             )
        )
    )
    (vlax-for layer (vla-get-layers acdoc)
        (vla-select acsel acselectionsetall nil nil typevar
            (vlax-make-variant
                (vlax-safearray-fill
                    (vlax-make-safearray vlax-vbvariant '(0 . 1)) (list (vla-get-name layer) "Model")
                )
            )
        )
        (if (< 0 (vla-get-count acsel))
            (progn
                (vla-wblock acdoc (_UniqueFilename (strcat fpath (vla-get-name layer))) acsel)
                (vla-clear acsel)
            )
        )
    )
    (vla-delete acsel)
    (princ)
)
(vl-load-com) (princ)



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

已领礼包: 1094个

财富等级: 财源广进

发表于 2021-11-15 00:41:34 | 显示全部楼层
感谢分享每个层单独保存DWG文件
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-26 02:12 , Processed in 0.167590 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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