设为首页收藏本站

晓东CAD家园-论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1118|回复: 19

[表格] 普通LINE,文字实体转换为表格

[复制链接]

已领礼包: 51个

财富等级: 招财进宝

发表于 2016-11-15 12:19:56 | 显示全部楼层 |阅读模式
  • 插件名称 : 转成表格
  • 作  者 : Lispboy
  • 运行环境 :XDRX API 晓东工具箱 
  • 发布时间 :2016-11-15
  • 命令名称 :XDTB_TableConvert
  • 插件介绍 :普通LINE,文字实体转换为表格
  • 备  注 : (点击图片可以放大)
(点击图片可以放大)

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

插件详细内容

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

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

x
本帖最后由 Lispboy 于 2016-11-15 12:24 编辑

将选择的TEXT,MTEXT,线,块(属性块)转换成表格实体。

需要在 2016.11.15以上版本的XDRX API下运行。

[sell]
(defun c:XDTB_TableConvert (/ #style #textheight area1 area2 att att1 blks box box1 col e
               el el1 ents gap h key pts rc row ss ss1 ss2 tb x y
            )
  (defun _gettbdata (col)
    (if (= (type col) 'ENAME)
      (progn
        (setq pts (xdrx_getpropertyvalue col "vertices"))
        (cond
          ((setq ss2 (ssget "wp" pts '((0 . "*TEXT"))))
            (setq ss2 (mapcar
                        '(lambda (y)
                           (xdrx_getpropertyvalue y "textheight")
                           (setq #style (car (xdrx_getpropertyvalue y "textstyle")))
                           (xdrx_getpropertyvalue y "textstring")
                         )
                        (xdrx_pickset->ents ss2)
                      )
            )
            (apply
              'strcat
              ss2
            )
          )
          ((setq ss2 (ssget "cp" pts '((0 . "INSERT"))))
            (setq e (ssname ss2 0)
                  ss2 (cadr (xdrx_getpropertyvalue e "blocktablerecord"))
            )
            (if (setq att (xdrx_getpropertyvalue e "AttributeEntities"))
              (progn
                (setq blks (xdrx_block_getentities ss2 '((0 . "att*")))
                      att1 (car blks)
                )
                (setq ss2 (list ss2 att1 (xdrx_getpropertyvalue
                                                                (car att) "textstring"
                                         )
                          )
                )
              )
            )
            ss2
          )
          (t
            (setq ss2 "")
          )
        )
      )
      nil
    )
  )
  (defun _getdata (ss)
    (if (and
          (setq el1 (xdrx_pickset->ents ss)
                ss1 (xd::pickset:getsub ss '((0 . "LINE,*POLYLINE")))
                ss1 (xdrx_curve_intersectbreak ss1)
                ss1 (xdrx_geom_searchregions ss1 0.0)
          )
        )
      (progn
        (setq box (xdrx_entity_box (cons ss1 el1))
              area1 (abs (apply
                           'xdrx_points_area
                           box
                         )
                    )
        )
        (setq e (xdrx_polyline_make box t)
              ss1 (xdrx_entity_explode ss1)
              ss1 (ssadd e ss1)
              ss1 (xdrx_curve_intersectbreak ss1)
              ss1 (xdrx_geom_searchregions ss1 0.0)
              el (xdrx_pickset->ents ss1)
        )
        (setq el (mapcar
                   '(lambda (x)
                      (setq area2 (xdrx_getpropertyvalue x "area"))
                      (if (equal area1 area2 1e-3)
                        (entdel x)
                        x
                      )
                    )
                   el
                 )
        )
        (setq el (vl-remove nil el))
        (setq e (car el)
              box1 (xdrx_entity_box e)
              h (distance (last box1) (car box1))
        )
        (xdrx_document_setprec (/ h 2.0) 1)
        (setq el (xd::pickset:tablesort ss1 0 2 '> '<)
              el (xd::table:fillgap el "")
              rc (xd::list:istable el)
        )
        (setq el (mapcar
                   '(lambda (row)
                      (mapcar
                        '(lambda (col)
                           (_gettbdata col)
                         )
                        row
                      )
                    )
                   el
                 )
        )
      )
      nil
    )
  )
  (defun _keyword (key)
    (cond
      ((= key "BJ")
        (if (setq gap (getint (xdrx_prompt "\n输入字到单元格边线距离系数(字高比值)<"
                                           #table_gap ">:" t
                              )
                      )
            )
          (setq #table_gap gap)
        )
      )
    )
    (xdrx_prompt "\n当前设置:字边距系数(" #table_gap ")")
  )
  (defun _settablehead ()
    (if (vl-every '(lambda (x)
                     (or
                       (= x "")
                       (= x nil)
                     )
                   ) (cdar el)
        )
      (progn
        (if (= (type (caaar el)) 'ENAME)
          (progn
            (if (xdrx_getpropertyvalue (caaar el) "HasAttributeDefinitions")
              (xdrx_setpropertyvalue tb "blockattributevalue" (list 0 0
                                                                    (cadr
                                                                          (caar el)
                                                                    )
                                                                    (last
                                                                          (caar el)
                                                                    )
                                                              )
              )
            )
            (xdrx_setpropertyvalue tb "autoscale" (list 0 0 nil)
                                   "blockscale" (list 0 0 1.0)
                                   "gridvisibility" (list 0 -1 41 1)
                                   "suppressTitleRow" nil
            )
          )
        )
      )
      (xdrx_setpropertyvalue tb "unmergecells" (list 0 0 0 (1-
                                                               (length
                                                                       (car el)
                                                               )
                                                           )
                                               ) "suppressTitleRow" t
      )
    )
  )
  (if (not #table_gap)
    (setq #table_gap 2)
  )
  (xdrx_prompt "\n当前设置:字边距系数(" #table_gap ")")
  (xdrx_initssget "\n选取要转换表格的线,文字实体[字边距(BJ)]<退出>" "BJ"
                  "移除不转换的实体[添加(A)]<退出>:" "_keyword" ""
  )
  (if (setq ss (xdrx_ssget '((0 . "LINE,*POLYLINE,*TEXT,INSERT"))))
    (progn
      (xdrx_begin)
      (xdrx_setmark)
      (setq ents (xdrx_pickset->ents ss))
      (if (setq el (_getdata ss))
        (progn
          (setq tb (xdrx_table_make (last box) (car rc) 1 (cadr rc) 1))
          (xdrx_setpropertyvalue tb "textstyle" #style "alignment" 5
                                 "textheight" #textheight "horzcellmargin"
                                 (/ #textheight #table_gap) "vertcellmargin"
                                 (/ #textheight #table_gap) "textstring" el
                                 "autosize"
          )
          (_settablehead)
          (setq ss1 (xdrx_getss)
                ss1 (ssdel tb ss1)
          )
          (xdrx_entity_delete ents ss1)
        )
        (xdrx_prompt "\n选择的线构不成表格.")
      )
      (xdrx_end)
    )
  )
  (princ)
)

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

已领礼包: 1304个

财富等级: 财源广进

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

使用道具 举报

已领礼包: 3198个

财富等级: 富可敌国

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

使用道具 举报

已领礼包: 87个

财富等级: 招财进宝

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

使用道具 举报

已领礼包: 9个

财富等级: 恭喜发财

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

使用道具 举报

已领礼包: 630个

财富等级: 财运亨通

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

使用道具 举报

已领礼包: 3181个

财富等级: 富可敌国

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

使用道具 举报

已领礼包: 6050个

财富等级: 富甲天下

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

使用道具 举报

已领礼包: 186个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 470个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 381个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 186个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 186个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 186个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 418个

财富等级: 日进斗金

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2021-3-5 15:46 , Processed in 0.182251 second(s), 43 queries , Gzip On, WinCache On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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