找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2879|回复: 4

[求助] 求CAD标注求和的程序

[复制链接]
发表于 2015-1-22 21:46:41 | 显示全部楼层 |阅读模式

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

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

×
1.如题。工作中经常要对门洞长度进行标注,最后还要统计所有门洞的总长度,有哪位大神可以给个标注求和的源代码,感激不尽!!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 10504个

财富等级: 富甲天下

发表于 2015-1-23 08:16:20 | 显示全部楼层
  1. (defun c:tt ()
  2. (setq sum 0.0)
  3. (if (setq ss (ssget '((0 . "DIMENSION"))))
  4. (repeat (setq i (sslength ss))
  5.   (setq ent (entget(ssname ss (setq i (1- i))))))
  6.   (setq txt (cdr(assoc 1 ent)))
  7.   (setq val (cdr(assoc 42 ent)))
  8.   (setq sum (+ sum (if (or (= txt "") (wcmatch txt "*<>*")) val) (atof txt))))
  9. )
  10. )
  11. (princ sum)
  12. (princ)
  13. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2015-2-9 15:35:42 | 显示全部楼层
大神,您好,感激不尽!

                               
登录/注册后可看大图
可以帮我再检查下吗?使用时提示语法错误 。

点评

(defun c:Tt (/ EN GET LEN NN NS STR X XF Y) (princ "\n功能 [框选标注求和]") (and (setq get (ssget '((0 . "DIMENSION")))) (progn (setq Len (sslength get)) (repeat Len (setq nn (ss  详情 回复 发表于 2015-3-11 14:26
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2015-3-11 14:26:21 | 显示全部楼层
930110534 发表于 2015-2-9 15:35
大神,您好,感激不尽!可以帮我再检查下吗?使用时提示语法错误 。

(defun c:Tt (/ EN GET LEN NN NS STR X XF Y)
  (princ "\n功能 [框选标注求和]")
  (and (setq get (ssget '((0 . "DIMENSION"))))
  (progn
  (setq        Len (sslength get))  
  (repeat Len
    (setq nn (ssname get (setq Len (1- Len)))
          en (entget nn)
          xf (cdr (assoc 42 en))
          ns (cons xf ns)
    )
  )
  (setq        str
         (substr
           (apply
             'strcat
             (list
               (apply
                 'strcat
                 (mapcar '(lambda (x) (strcat "+" x))
                         (mapcar '(lambda (y) (rtos y 2 2)) ns)
                 )
               )
               (strcat "=" (rtos (apply '+ ns) 2 2))
             )
           )
           2
         )
  )
  (princ (strcat "\n☆☆☆ 表达式 < " str "mm > ☆☆☆"))
         )
  )
  (princ)
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2015-3-11 17:32:30 | 显示全部楼层
第一个插件第8行多了一个”)“
  (setq sum (+ sum (if (or (= txt "") (wcmatch txt "*<>*")) val ) (atof txt))))

如果有兴趣量身定制自己的插件,欢迎光临鄙店,我们将会为您提供最优质的服务,谢谢
http://item.taobao.com/item.htm? ... &id=44087801664
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-22 10:49 , Processed in 0.458119 second(s), 41 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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