找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2984|回复: 12

[统计] 线长分组统计表(第二版)

[复制链接]

已领礼包: 40个

财富等级: 招财进宝

发表于 2018-7-19 17:37:21 | 显示全部楼层 |阅读模式
  • 插件名称 : 线长分组
  • 作  者 : newer
  • 运行环境 :XDRX API 晓东工具箱 
  • 发布时间 :2018-07-19
  • 命令名称 :XDTB_TJXIANC
  • 插件介绍 :根据线长分组后列出统计表
  • 备  注 : (点击图片可以放大)
(点击图片可以放大)

晓东温馨提示 1、运行环境为 晓东工具箱XDRX API 的插件,请下载最新版本的 晓东工具箱XDRX API开发环境 一键安装
2、在ACAD中如何加载插件,请看 论坛插件使用方法
3、如果您有要求需要定制插件,请到 编程申请 论坛发帖求助

插件详细内容

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

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

×
工作中,有时候需要按长度的分组统计下线的长度,比如下料的统计等等,下面代码完成这个工作,把线长相同的分成组,然后列出每组的单位长度,总数量,总长度,
最后有总的合计。


  1. (defun c:XDTB_TJXIANC (/ h lst scl ss x y)
  2.   (defun my_err (msg)
  3.     (xdrx_prompt "\n" msg)
  4.     (xdrx_pointmonitor)
  5.     (xdrx_end)
  6.     (xd::doc:command (list ".undo" 1))
  7.     (setq *error* nil)
  8.   )
  9.   (if (not #txt_height)
  10.     (setq #txt_height 3.5)
  11.   )
  12.   (if (not #xd_var_global_bits)
  13.     (setq #xd_var_global_bits 1)
  14.   )
  15.   (if (setq val (getint
  16.                   (xdrx_prompt "\n保留位数<" #xd_var_global_bits ">:" t)
  17.                 )
  18.       )
  19.     (setq #xd_var_global_bits val)
  20.   )
  21.   (if (setq val (getreal (xdrx_prompt "\n字高<" #txt_height ">:" t)))
  22.     (setq #txt_height val)
  23.   )
  24.   (xdrx_initssget "\n选取要统计的线和多段线<退出>:")
  25.   (if (setq ss (xdrx_ssget '((0 . "LINE,*POLYLINE"))))
  26.     (progn (xdrx_begin)
  27.            (xdrx_sysvar_push '("dimzin" 0))
  28.            (setq *error* my_err)
  29.            (setq lst (mapcar '(lambda (x) (list (xdrx_getpropertyvalue x "length") x))
  30.                              (xdrx_pickset->ents ss)
  31.                      )
  32.                  lst (xd::list:groupbyindex lst 1e-3)
  33.                  lst (vl-sort lst '(lambda (x y) (< (car x) (car y))))
  34.                  i   0
  35.                  lst (mapcar '(lambda (x)
  36.                                 (list (itoa (setq i (1+ i)))
  37.                                       (rtos (car x) 2 #xd_var_global_bits)
  38.                                       (setq num (length (cdr x)))
  39.                                       (rtos (* num (car x)) 2 #xd_var_global_bits)
  40.                                 )
  41.                               )
  42.                              lst
  43.                      )
  44.                  lst (append lst
  45.                              (list
  46.                                (list "合 计"
  47.                                      (rtos (apply '+ (mapcar '(lambda (y) (atof (cadr y))) lst))
  48.                                            2
  49.                                            #xd_var_global_bits
  50.                                      )
  51.                                      (itoa (apply '+ (mapcar '(lambda (y) (caddr y)) lst)))
  52.                                      (rtos (apply '+ (mapcar '(lambda (y) (atof (last y))) lst))
  53.                                            2
  54.                                            #xd_var_global_bits
  55.                                      )
  56.                                )
  57.                              )
  58.                      )
  59.                  lst (cons (list "序 号" "长  度" "数  量" "总 长") lst)
  60.                  lst (cons (list "长度分组统计表" nil nil nil) lst)
  61.            )
  62.            (xd::text:init 1)
  63.            (setq scl (* (xd::var:getratio) (xd::var:getscaleratio))
  64.                  h   (* #txt_height scl)
  65.            )
  66.            (xd::table:makefromlist lst '(0 0 0) h (/ h 2.0))
  67.            (if (vl-catch-all-error-p
  68.                  (vl-catch-all-apply
  69.                    'XD::Drag:SimpleMove
  70.                    (list (entlast) "\n表格插入点:" 8 t)
  71.                  )
  72.                )
  73.              (xdrx_entity_delete (entlast))
  74.            )
  75.            (xdrx_sysvar_pop)
  76.            (xdrx_end)
  77.     )
  78.   )
  79.   (princ)
  80. )


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

已领礼包: 69个

财富等级: 招财进宝

发表于 2018-7-19 17:46:59 | 显示全部楼层
本帖最后由 zhangfaren 于 2018-7-19 17:57 编辑

这个太强大了,如果能在线段上也标记序号,就可以和表格上的序号对应起来,这样子就完美了!

点评

这个主要是统计材料量的,如果有N多的线,编上号图就太乱了。 你要标注选择的长度,论坛有别的插件。直接把长度标注到线上。  详情 回复 发表于 2018-7-19 18:27
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 20个

财富等级: 恭喜发财

发表于 2018-7-19 18:19:52 | 显示全部楼层
代码复制粘贴后出现空格被问号替代的情况,怎么弄

点评

1、自己鼠标亮选择代码后,拷贝 2、你在编辑器发现? , 你用编辑器的全盘替换,把?替换无就行了。  详情 回复 发表于 2018-7-19 18:26
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 40个

财富等级: 招财进宝

 楼主| 发表于 2018-7-19 18:26:03 | 显示全部楼层
moranyuyan 发表于 2018-7-19 18:19
代码复制粘贴后出现空格被问号替代的情况,怎么弄

1、自己鼠标亮选择代码后,拷贝
2、你在编辑器发现? , 你用编辑器的全盘替换,把?替换无就行了。

点评

将鼠标放在代码的行数上复制就不会出现这个问题了,刚刚试过  详情 回复 发表于 2018-7-19 18:29
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 40个

财富等级: 招财进宝

 楼主| 发表于 2018-7-19 18:27:27 | 显示全部楼层
zhangfaren 发表于 2018-7-19 17:46
这个太强大了,如果能在线段上也标记序号,就可以和表格上的序号对应起来,这样子就完美了!

这个主要是统计材料量的,如果有N多的线,编上号图就太乱了。

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

使用道具 举报

已领礼包: 20个

财富等级: 恭喜发财

发表于 2018-7-19 18:29:13 | 显示全部楼层
newer 发表于 2018-7-19 18:26
1、自己鼠标亮选择代码后,拷贝
2、你在编辑器发现? , 你用编辑器的全盘替换,把?替换无就行了。

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

使用道具 举报

已领礼包: 1个

财富等级: 恭喜发财

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

使用道具 举报

已领礼包: 154个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 38个

财富等级: 招财进宝

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

使用道具 举报

发表于 2019-5-2 17:39:03 | 显示全部楼层
N版主,此脚本能否改成在列出表格的时候,长度按照从长到短的排列,或者2者有个选择?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 7个

财富等级: 恭喜发财

发表于 2020-5-17 22:38:47 | 显示全部楼层
斑竹,介个插件能否再给个简单的不分组的,只按选取顺序列表。其实好多工具箱都缺少这样的插件。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 19个

财富等级: 恭喜发财

发表于 2020-5-18 00:03:26 | 显示全部楼层
bszzl167 发表于 2020-5-17 22:38
斑竹,介个插件能否再给个简单的不分组的,只按选取顺序列表。其实好多工具箱都缺少这样的插件。

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

使用道具 举报

已领礼包: 7个

财富等级: 恭喜发财

发表于 2020-5-18 09:04:01 | 显示全部楼层
Lisphk 发表于 2020-5-18 00:03
你要一个一个去点吗? 窗口选,不是更快

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-26 18:45 , Processed in 0.476344 second(s), 57 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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