找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1850|回复: 1

[] (XD::List:toTableValue)对按行排列的表构造Table Value

[复制链接]

已领礼包: 593个

财富等级: 财运亨通

发表于 2014-12-30 08:58:31 | 显示全部楼层 |阅读模式
函数发布
函数名称: XD::List:toTableValue
调用格式: (XD::List:toTableValue lst fuzz)
参数说明: lst -- 使用 xd::list:tablesort 按行排列后的表
fuzz -- 列宽误差
返回值: 表 ,Table Value 格式
函数简介: 对按行排列的表构造Table Value
函数来源: 原创
函数作者: eachy
适用版本: 不限 
最后更新时间: 2014-12-30
备注: -
演示图片: -

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

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

×
  1. (defun XD::List:ToTableValue (lst fuzz / pts xcoord pl)
  2.   (setq        pts    (apply 'append (mapcar '(lambda (x) (mapcar 'caar x)) lst))
  3.         xcoord (vl-sort pts '<)
  4.         pl     (list (car xcoord))
  5.         xcoord (cdr xcoord)
  6.   )
  7.   (while xcoord
  8.     (if        (equal (car xcoord) (car pl) fuzz)
  9.       (setq xcoord (cdr xcoord))
  10.       (setq pl           (cons (car xcoord) pl)
  11.             xcoord (cdr xcoord)
  12.       )
  13.     )
  14.   )
  15.   (setq pl (reverse pl))
  16.   (mapcar '(lambda (x)
  17.              (mapcar '(lambda (a / l)
  18.                         (if (setq l
  19.                                    (vl-member-if
  20.                                      '(lambda (b)
  21.                                         (equal (caar b) a fuzz)
  22.                                       )
  23.                                      x
  24.                                    )
  25.                             )
  26.                           (car l)
  27.                           nil
  28.                         )
  29.                       )
  30.                      pl
  31.              )
  32.            )
  33.           lst
  34.   )
  35. )

测试
  1. (defun c:tt (/ ss lst d0 d1)
  2.   (if (and (setq ss (ssget '((0 . "text"))))
  3.            (setq d0 (getdist "\n行误差: "))
  4.            (setq d1 (getdist "\n列误差: "))
  5.       )
  6.     (progn
  7.       (setq lst        (mapcar        '(lambda (x)
  8.                            (xdrx_getpropertyvalue x "Position" "textstring")
  9.                          )
  10.                         (xdrx_pickset->ents ss)
  11.                 )
  12.             lst        (xd::list:tablesort lst 0 3 d0)
  13.             lst        (XD::List:ToTableValue lst d1)
  14.       )
  15.     )
  16.   )
  17. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2015-2-26 12:14:13 | 显示全部楼层
;PXD::List:toTableValue:loveliness:
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 13:33 , Processed in 0.365452 second(s), 31 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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