明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3003|回复: 7

VLISP如何获取已打开DWG的列表和关闭某个指定的dwg

[复制链接]
发表于 2013-1-20 21:12:58 | 显示全部楼层 |阅读模式
本帖最后由 masterlong 于 2013-1-20 21:13 编辑

问题1:
如何获取已打开DWG的列表
问题2:
假设已打开1.dwg 2.dwg 3.dwg
当前活动文件是1.dwg
如何关闭3.dwg
"觉得好,就打赏"
还没有人打赏,支持一下
 楼主| 发表于 2013-1-20 21:22:43 | 显示全部楼层
;;一个VLISP的批量处理范例
;;从这个范例可以了解VLISP如何批量处理图档
;;虽然速度慢了点,但非常实用
;;By LUCAS(龙龙仔)
;;从文件移除未使用之具名参考                                 
;;                                                           
;;虽配合Expresstools__(acetutil.arx)                        
;;为加速程序执行,程序将设定系统变量ACADLSPASDOC              
;;即<只载入 acad.lsp 至 AutoCAD 执行期所开启的第一个图面>   
;;当然程序结束后,会还原系统变量ACADLSPASDOC
;;                 
;;Usage: (PURGEALL <循环次数>)                                                            
;;Usage: (PURGEALL 5)                                       

(arxload "acetutil.arx" NIL)
(vl-load-com)
(defun PURGEALL(TIMES / HOLDECHO APP DWGNAME PREFIX_DWG NN QQ HOLDLSP WW)
  (setq HOLDECHO (getvar "cmdecho"))
  (setvar "cmdecho" 0)
  (setq PREFIX_DWG
         (strcat
           (strcase (acet-ui-pickdir
                      "选择目录"
                      (vl-string-right-trim "\\" (getvar "dwgprefix"))
                      "移除未使用之具名参考"
                    )
           )
           "\\"
         )
  )
  (setq HOLDLSP (getvar "ACADLSPASDOC"))
  (setvar "acadlspasdoc" 0)
  (setq QQ (vl-directory-files PREFIX_DWG "*.DWG"))
  (setq NN 0)
  (if (/= QQ NIL)
    (progn
      (setq APP (vlax-get-acad-object))
      (repeat (length QQ)
        (setq DWGNAME (strcase (strcat PREFIX_DWG (nth NN QQ))))
        (if (not (vl-catch-all-apply
                   'vla-open
                   (list (vla-get-documents APP) DWGNAME)
                 )
            )
          (progn
            (repeat TIMES (vla-purgeall WW))
            (vla-save WW)
            (prompt (strcat "\n" DWGNAME " <PURGE完成>!!!"))
            (vla-close WW :vlax-false)
          )
        )
        (setq NN (1+ NN))
      )
      (vlax-release-object WW)
      (vlax-release-object APP)
    )
    (prompt "\n所选目录中未有任何图档!!!")
  )
  (setvar "acadlspasdoc" HOLDLSP)
  (setvar "cmdecho" HOLDECHO)
  (princ)
)
(princ)

这个程序运行不成功
红色文字中的ww是什么?
发表于 2013-1-20 21:37:06 | 显示全部楼层
支持一下,
 楼主| 发表于 2013-1-21 14:42:37 | 显示全部楼层
找到第2贴的原贴了
联接如下
http://bbs.mjtd.com/forum.php?mod=viewthread&tid=4647

利用该程序的思路
算是曲线救国解决了我的问题

不过
有没有办法获取已打开dwg文件的列表
并且指定某个文件关闭呢
我看doslib里也只有"关闭全部"的功能
发表于 2013-1-21 16:09:05 | 显示全部楼层
本帖最后由 xiaxiang 于 2013-1-21 17:02 编辑
masterlong 发表于 2013-1-21 14:42
找到第2贴的原贴了
联接如下
http://bbs.mjtd.com/forum.php?mod=viewthread&tid=4647

有没有办法获取已打开dwg文件的列表
  1. (defun Get:OpenDrawings ( / *dwg* *acdocs*)
  2. (vlax-for <doc>  (vla-get-documents (vlax-get-acad-object))
  3.   (if (eq "" (setq *dwg* (vla-get-fullname <doc>)))
  4.   (setq *dwg* (vla-get-name <doc>))
  5.   )
  6.   (setq *acdocs* (cons (cons (strcase *dwg*) <doc>) *acdocs*))
  7. )
  8. (reverse *acdocs*)
  9. )

  10. (Get:OpenDrawings)
并且指定某个文件关闭


  1. ;;dwgName  ->file name "Drawing3.dwg"
  2. ;;bSave    -> t save
  3. ;;         ->nil not save
  4. (defun CloseAndSave ( dwgName bSave / myDocs myDoc)
  5. (setq myDocs (vla-Get-Documents (vlax-get-acad-object))
  6.          myDoc (vla-Item myDocs dwgName))
  7.     (vlax-for i myDocs
  8.         (if (= (strcase dwgName) (strcase (vla-get-Name i)))
  9.             (if
  10.                 (and
  11.                     bSave
  12.      myDoc
  13.                     (equal (vla-get-ReadOnly i) :vlax-false)
  14.      (equal (vla-get-Active i) :vlax-false)
  15.                 )
  16.                 (vla-Close i :vlax-true)
  17.                 (vla-Close i :vlax-false)
  18.             )
  19.         )
  20.     )
  21. )
如果需要关闭当前文档,lisp似乎做不到,只有依赖VBA表达式

  1. (command "vbastmt" "activedocument.close false")

 楼主| 发表于 2013-1-23 11:33:02 | 显示全部楼层
非常感谢

lisp关闭当前文档
可以用下面的方式吧
(command "close")

点评

(command "close")有可能会提示存盘  发表于 2013-3-11 15:14
发表于 2013-3-11 15:09:44 | 显示全部楼层
xiaxiang 发表于 2013-1-21 16:09
如果需要关闭当前文档,lisp似乎做不到,只有依赖VBA表达式

请教,我这样做,为什么不能正确关闭?

;;并且指定某个文件关闭
;;dwgName  ->file name "Drawing3.dwg"
;;bSave    -> t save
;;         ->nil not save
(defun CloseAndSave ( dwgName bSave / myDocs myDoc)
(setq myDocs (vla-Get-Documents (vlax-get-acad-object))
         myDoc (vla-Item myDocs dwgName))
    (vlax-for i myDocs
        (if (= (strcase dwgName) (strcase (vla-get-Name i)))
            (if
                (and
                    bSave
     myDoc
                    (equal (vla-get-ReadOnly i) :vlax-false)
     (equal (vla-get-Active i) :vlax-false)
                )
                (vla-Close i :vlax-true)
                (vla-Close i :vlax-false)
            )
        )
    )
)

(defun TT ( )
(CloseAndSave ("Drawing3.dwg" T))
(princ)  
)
发表于 2013-3-11 15:17:27 | 显示全部楼层
Ccccccc 发表于 2013-3-11 15:09
请教,我这样做,为什么不能正确关闭?

;;并且指定某个文件关闭

(CloseAndSave ("Drawing3.dwg" T))
------>
(CloseAndSave "Drawing3.dwg" T)

点评

多谢~~  发表于 2013-3-11 17:11
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-12-23 23:36 , Processed in 0.201541 second(s), 31 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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