找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 786|回复: 4

[每日一码] 列出所有图层实体数量

[复制链接]

已领礼包: 20个

财富等级: 恭喜发财

发表于 2018-11-22 15:02:42 | 显示全部楼层 |阅读模式

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

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

×

  1. (defun c:layercount (/ lst)
  2.   (vlax-for blk (vla-get-blocks
  3.                   (vla-get-activedocument (vlax-get-acad-object))
  4.                 )
  5.     (vlax-for obj blk
  6.       (setq lst (layercount:assoc++ (vla-get-layer obj) lst))
  7.       (if (and (= "AcDbBlockReference" (vla-get-objectname obj))
  8.                (= :vlax-true (vla-get-hasattributes obj))
  9.           )
  10.         (foreach att (vlax-invoke obj 'getattributes)
  11.           (setq lst (layercount:assoc++ (vla-get-layer att) lst))
  12.         )
  13.       )
  14.     )
  15.   )
  16.   (princ (layercount:padbetween "\n\n" "" "-" 62))
  17.   (princ (layercount:padbetween "\nLayer" "Objects" " " 61))
  18.   (princ (layercount:padbetween "\n" "" "-" 61))
  19.   (foreach itm (vl-sort lst '(lambda (a b) (> (cdr a) (cdr b))))
  20.     (princ (layercount:padbetween
  21.              (strcat "\n" (car itm))
  22.              (itoa (cdr itm))
  23.              "."
  24.              61
  25.            )
  26.     )
  27.   )
  28.   (princ (layercount:padbetween "\n" "" "-" 61))
  29.   (princ (layercount:padbetween
  30.            "\nTotal"
  31.            (itoa (apply '+ (mapcar 'cdr lst)))
  32.            "."
  33.            61
  34.          )
  35.   )
  36.   (princ (layercount:padbetween "\n" "" "-" 61))
  37.   (textpage)
  38.   (princ)
  39. )
  40. (defun layercount:assoc++ (key lst / itm)
  41.   (if (setq itm (assoc key lst))
  42.     (subst (cons key (1+ (cdr itm))) itm lst)
  43.     (cons (cons key 1) lst)
  44.   )
  45. )
  46. (defun layercount:padbetween (s1 s2 ch ln)
  47.   ((lambda (a b c)
  48.      (repeat (- ln (length b) (length c)) (setq c (cons a c)))
  49.      (vl-list->string (append b c))
  50.    )
  51.     (ascii ch)
  52.     (vl-string->list s1)
  53.     (vl-string->list s2)
  54.   )
  55. )

  56. (vl-load-com)
  57. (princ)




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

已领礼包: 104个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 6434个

财富等级: 富甲天下

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

使用道具 举报

已领礼包: 158个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 8732个

财富等级: 富甲天下

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-4 20:17 , Processed in 0.177447 second(s), 39 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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