设为首页收藏本站

晓东CAD家园-论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 989|回复: 5

[表格] 表格式文字按行、按列相加(第二版)

[复制链接]

已领礼包: 145个

财富等级: 日进斗金

发表于 2018-7-25 13:27:23 | 显示全部楼层 |阅读模式
  • 插件名称 : 数字相加
  • 作  者 : XDSoft
  • 运行环境 :XDRX API 晓东工具箱 
  • 发布时间 :2018-07-25
  • 命令名称 :XDTB_TextSumByRC
  • 插件介绍 :表格式文字按行、按列相加
  • 备  注 : (点击图片可以放大)
(点击图片可以放大)

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

插件详细内容

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

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

x
  1. (defun c:XDTB_TextSumByRC (/ val tf ss e1 h w entl el p1 sum m x txt plane mat box pj)
  2.   (xdrx_begin)
  3.   (if (not #xd_var_global_bits)
  4.     (setq #xd_var_global_bits 1)
  5.   )
  6.   (if (setq val (getint
  7.                   (xdrx_prompt "\n保留位数<" #xd_var_global_bits ">:" t)
  8.                 )
  9.       )
  10.     (setq #xd_var_global_bits val)
  11.   )
  12.   (xdrx_initget "0 1")
  13.   (if (not (setq tf (getint "\n计算方式[0-按行/1-按列]<1>:")))
  14.     (setq tf 1)
  15.   )
  16.   (princ (strcat "\n选取"
  17.                  (if (= tf 1)
  18.                    "按列"
  19.                    "按行"
  20.                  )
  21.                  "求和的数字文字<退出>:"
  22.          )
  23.   )
  24.   (xdrx_initget)
  25.   (while (and (xdrx_initssget
  26.                 (strcat "\n选取"
  27.                         (if (= tf 1)
  28.                           "按列"
  29.                           "按行"
  30.                         )
  31.                         "求和的数字文字<退出>:"
  32.                 )
  33.               )
  34.               (setq ss (xdrx_ssget '((0 . "TEXT"))))
  35.          )
  36.     (progn (setq e1  (ssname ss 0)
  37.                  box (XD::Entity:BoxAtEcs e1 e1)
  38.                  h   (xdrx_text_height e1)
  39.                  w   (distance (car box) (cadr box))
  40.            )
  41.            (xdrx_document_setPrec
  42.              (if (= tf 1)
  43.                w
  44.                h
  45.              )
  46.              1.0
  47.            )
  48.            (setq xdir (cadr (xdrx_entity_getecs (ssname ss 0))))
  49.            (setq entl (XD::Pickset:TableSortAtEcs ss xdir tf 0 '< '<))
  50.            (setq el (mapcar '(lambda (x)
  51.                                (setq sum 0)
  52.                                (foreach m x
  53.                                  (setq txt2 (xdrx_text_string m))
  54.                                  (if (XD::String:IsNum txt2)
  55.                                    (setq sum (+ sum (atof txt2)))
  56.                                  )
  57.                                )
  58.                                (list (car x) (rtos sum 2 #xd_var_global_bits))
  59.                              )
  60.                             entl
  61.                     )
  62.            )
  63.            (if (setq p1 (getpoint "\n插入点<退出>:"))
  64.              (progn (setq mat0 (xdrx_matrix_identity 3))
  65.                     (foreach n el
  66.                       (setq e     (car n)
  67.                             txt   (cadr n)
  68.                             box   (xdrx_entity_box e t)
  69.                             box   (xd::pnts:ucs2wcs box)
  70.                             plane (apply 'XD::Geom:GetPerpPlaneWithLine
  71.                                          (if (= tf 1)
  72.                                            (list (car box) (last box) (xdrx_text_normal e))
  73.                                            (list (car box) (cadr box) (xdrx_text_normal e))
  74.                                          )
  75.                                   )
  76.                             pj    (xdrx_point_orthoproject (trans p1 1 0) plane)
  77.                             mat   (xdrx_matrix_setTransLation
  78.                                     mat0
  79.                                     (mapcar '- pj (xdrx_getpropertyvalue e "position"))
  80.                                   )
  81.                       )
  82.                       (xdrx_entity_transformedcopy e mat)
  83.                       (xdrx_text_setstring (entlast) txt)
  84.                       (xdrx_entity_setpropertiesfrom (entlast) e)
  85.                     )
  86.              )
  87.            )
  88.     )
  89.   )
  90.   (xdrx_end)
  91.   (princ)
  92. )


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

已领礼包: 8308个

财富等级: 富甲天下

发表于 2018-7-25 15:12:25 | 显示全部楼层
能扩展为四则运算吗?

点评

在CAD里面,逻辑不好加,对话框也不好设置, 导到EXCEL里面多方便,算完,在导进来,都有插件。  详情 回复 发表于 2018-7-25 16:08
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 145个

财富等级: 日进斗金

 楼主| 发表于 2018-7-25 16:08:07 | 显示全部楼层
liuyj 发表于 2018-7-25 15:12
能扩展为四则运算吗?

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

使用道具 举报

已领礼包: 8308个

财富等级: 富甲天下

发表于 2018-7-25 16:55:27 | 显示全部楼层
其实我用的多的是相乘,就稍微改了一下。减和除麻烦点,就不弄了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2021-9-19 04:10 , Processed in 0.643090 second(s), 42 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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