找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1288|回复: 1

[表格] (XD::Table:setMerge)合并表格的单元格

[复制链接]

已领礼包: 51个

财富等级: 招财进宝

发表于 2016-7-19 00:45:26 | 显示全部楼层 |阅读模式
函数发布
函数名称: XD::Table:setMerge
调用格式: (XD::Table:setMerge tb minrow maxrow mincol maxcol)
参数说明: tb ------ AUTOCAD表格实体 or XTable实体 or "sheet"
返回值: T or NIL
函数简介: 合并表格的单元格
函数来源: 原创
函数作者: LispBoy
适用版本: XDRX API 
最后更新时间: 2016-07-19
备注: 根据TB参数,可以操作AUTOCAD表格实体,晓东表格(XTable)和EXCEL 表
演示图片: -

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

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

×
本帖最后由 Lispboy 于 2016-7-19 01:14 编辑

  1. (defun XD::Table:setMerge (tb minrow maxrow mincol maxcol / ); bent box col el el1 ex handle n row typ x xdir)
  2.   (setq typ (XD::Table:TYPE tb)
  3.         xdir (XD::Table:direction tb)
  4.   )
  5.   (cond
  6.     ((= typ "X")
  7.       (setq el (xdrx_block_getentities tb)
  8.             el1 nil
  9.       )
  10.       (foreach n el
  11.         (setq ex (xdrx_object_getxrecord n "no")
  12.               row (atoi (car ex))
  13.               col (atoi (cadr ex))
  14.         )
  15.         (if (and
  16.              (>= row minrow)
  17.              (<= row maxrow)
  18.              (>= col mincol)
  19.              (<= col maxcol)
  20.            )
  21.           (progn
  22.             (setq el1 (cons n el1))
  23.           )
  24.         )
  25.       )
  26.       (if (setq box (xdrx_entity_box el1 xdir))
  27.         (progn
  28.           (XD::Table:drawcell tb (last box) (distance (car box)
  29.                                                       (cadr box)
  30.                                             ) (distance (cadr box)
  31.                                                         (caddr box)
  32.                                               )
  33.           )
  34.           (setq bent (car (xdrx_block_appendentity (car
  35.                                                         (xdrx_getpropertyvalue tb "blocktablerecord")
  36.                                                    ) (entlast) t
  37.                           )
  38.                      )
  39.           )
  40.           (xdrx_object_setxrecord bent "MergeCell" 1)
  41.           (xdrx_object_setxrecord bent "no" (list (itoa minrow)
  42.                                                   (itoa mincol)
  43.                                             )
  44.           )
  45.           (xdrx_object_setxrecord bent "scope" (list minrow maxrow mincol
  46.                                                      maxcol
  47.                                                )
  48.           )
  49.           (setq handle (xdrx_getpropertyvalue bent "handle"))
  50.           (mapcar '(lambda(x)(xdrx_object_setxrecord x "MergeCellEnt" handle))el1)
  51.           (xdrx_entity_setproperty el1 "visibility" nil)
  52.           (xdrx_object_setxrecord tb "mergecells" (cons
  53.                                                         handle
  54.                                                         (xdrx_object_getxrecord tb "mergecells")
  55.                                                   )
  56.           )
  57.           (xdrx_object_regen tb)
  58.         )
  59.       )
  60.     )
  61.     ((= typ "A")
  62.       (xdrx_table_mergecells tb minrow maxrow mincol maxcol)
  63.     )
  64.     ((= typ "E")
  65.       (xdex_sheet_setMerge minrow maxrow mincol maxcol)
  66.     )
  67.   )
  68. )

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2021-4-21 21:12:12 | 显示全部楼层
请问用程序生成了表格,但是有很多相同的内容,如何合并相内容的单元格?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 02:05 , Processed in 0.170566 second(s), 32 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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