找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 578|回复: 2

[每日一码] 批量搜索DWG,列出图中填充面积异常的文件

[复制链接]

已领礼包: 20个

财富等级: 恭喜发财

发表于 2017-12-22 11:52:19 | 显示全部楼层 |阅读模式

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

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

×
本帖最后由 marting 于 2017-12-22 11:53 编辑


填充异常,就是填充面积为0的。图中有填充面积为0的,不好发现,统计工程量时候就出问题了。
下面代码,不需要打开DWG,批量搜索指定目录的DWG文件,找到后,文本屏幕打印出来文件名。


需要加载  晓东通用LISP函数库。或到开源函数库论坛找需要函数的代码。
xd::vla:catchapply
xd::vla:odbx

  1. (defun c:tt ()
  2.   (defun _find (doc)
  3.     (textpage)
  4.     (setq dwglst nil)
  5.     (princ (strcat "\n搜索 " (setq dwg (vla-get-name doc))))
  6.     (setq layouts (vla-get-layouts doc))
  7.     (setq dwglst nil)
  8.     (vlax-for lay layouts
  9.       (setq blk (vla-get-block lay))
  10.       (setq tf t
  11.             i  -1
  12.       )
  13.       (while
  14.         (and tf
  15.              (setq
  16.                o (xd::vla:catchapply vla-item (list blk (setq i (1+ i))))
  17.              )
  18.         )
  19.          (if (and (= (vla-get-objectname o) "AcDbHatch")
  20.                   (not (xd::vla:catchapply vla-get-area (list o)))
  21.              )
  22.            (progn (setq tf nil)
  23.                   (setq dwglst (cons (vla-get-name doc) dwglst))
  24.            )
  25.          )
  26.       )
  27.     )
  28.     (if dwglst
  29.       (progn (princ "\n\n**********************\n发现异常填充,请核查.\n")
  30.              (mapcar '(lambda (x) (princ "\n") (princ x)) dwglst)
  31.       )
  32.     )
  33.   )
  34.   (xd::vla:odbx '_find nil nil)
  35.   (princ)
  36. )


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

已领礼包: 19个

财富等级: 恭喜发财

发表于 2017-12-22 12:16:36 | 显示全部楼层
那发现了0面积填充,怎么办?能算出来吗?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 40个

财富等级: 招财进宝

发表于 2017-12-22 12:37:05 | 显示全部楼层

晓东工具箱里面算面积的工具,都能算异常填充的面积

下面是简短算填充面积的代码

  1. (defun c:tt ()
  2.   (if (and (xdrx_initssget "选择计算的填充<退出>")
  3.            (setq ss (xdrx_ssget '((0 . "HATCH"))))
  4.       )
  5.     (progn (setq ar  (xdrx_entity_getproperty ss "area")
  6.                  ar  (apply '+ ar)
  7.            )
  8.            (xdrx_prompt "\n填充总面积为:" (rtos ar 2 1))
  9.     )
  10.   )
  11.   (princ)
  12. )

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-6-15 03:28 , Processed in 0.403985 second(s), 32 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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