找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1583|回复: 4

[选择集] 多个选择集,图元表,图元转为选择集

[复制链接]
发表于 2016-8-11 16:12:07 | 显示全部楼层 |阅读模式
函数发布
函数名称: X2SS
调用格式: (X2SS lst)
参数说明: lst为表,其内元素类型包含但不限于:选择集、图元名表、图元名,也可以为entsel返回值
返回值: 选择集(表内任意元素为图元或者包含图元,当表内有选择集时,所有图元合并到第一个选择集中,如果不含选择集,将新建一个选择集)
nil(表内无选择集也无图元,或者表内有图元无选择集,但图内选择集已经达到128个)
函数简介: 不限数据类型合并图元到选择集
函数来源: 原创
函数作者: llsheng_73
适用版本: 不限 
最后更新时间: 2016-08-11
备注: -
演示图片: -

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

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

×
[code=list](defun x2ss(ssl / s2es etype el ss a)
  (defun s2es(s)(reverse(mapcar'cadr(member(nth(1-(sslength s))(setq s(ssnamex s)))(reverse s)))))
  (foreach x ssl
    (setq etype(type x))
    (cond((= etype'ename)(setq el(cons x el)))
  ((= etype'pickset)(setq ss(cons x ss)))
  ((= etype'list)(setq el(append(vl-remove-if-not'(lambda(x)(=(type x)'ename))x)el)))))
  (setq a(if ss(last ss)(if el(ssadd))))
  (vl-every'(lambda(x)(ssadd x a))(apply'append(cons el(mapcar's2es(cdr(reverse ss))))))
  a)[/code]
QQ截图20160811160500.jpg
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 1742个

财富等级: 堆金积玉

发表于 2016-8-11 16:19:09 | 显示全部楼层
我替楼主格式化了
  1. (defun x2ss (ssl / s2es etype el ss a)
  2.   (defun s2es (s)
  3.     (reverse (mapcar
  4.                'cadr
  5.                (member (nth (1- (sslength s)) (setq s (ssnamex s)))
  6.                        (reverse s)
  7.                )
  8.              )
  9.     )
  10.   )
  11.   (foreach x ssl
  12.     (setq etype (type x))
  13.     (cond
  14.       ((= etype 'ename)
  15.         (setq el (cons x el))
  16.       )
  17.       ((= etype 'pickset)
  18.         (setq ss (cons x ss))
  19.       )
  20.       ((= etype 'list)
  21.         (setq el (append
  22.                    (vl-remove-if-not '(lambda (x)
  23.                                         (= (type x) 'ename)
  24.                                       ) x
  25.                    )
  26.                    el
  27.                  )
  28.         )
  29.       )
  30.     )
  31.   )
  32.   (setq a (if ss
  33.             (last ss)
  34.             (if el
  35.               (ssadd)
  36.             )
  37.           )
  38.   )
  39.   (vl-every '(lambda (x)
  40.                (ssadd x a)
  41.              ) (apply
  42.                  'append
  43.                  (cons el (mapcar's2es (cdr (reverse ss))))
  44.                )
  45.   )
  46.   a
  47. )

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

使用道具 举报

发表于 2016-8-12 08:16:21 | 显示全部楼层
老乡呀,你是不是把简单问题复杂化了,看看俺们的ss+ Lst=>ss

点评

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

使用道具 举报

 楼主| 发表于 2016-8-12 10:21:15 | 显示全部楼层
WhoCanSay 发表于 2016-8-12 08:16
老乡呀,你是不是把简单问题复杂化了,看看俺们的ss+ Lst=>ss

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

使用道具 举报

已领礼包: 8987个

财富等级: 富甲天下

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 06:46 , Processed in 0.378195 second(s), 45 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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