找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1080|回复: 9

[LISP程序]:号码重新编号与排序

[复制链接]
发表于 2004-12-8 07:52:50 | 显示全部楼层 |阅读模式

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

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

×
号码重新编号与排序
功能:框选过滤文本字符串号码;
      可选起始号码;
      可选号码增量;
      可选上下左右排列号码。
欢迎试用,提出意见。
[PHP]
(defun c:test ()
  (setq ss (ssget '((0 . "TEXT"))))
  (setq ll (acet-ss-to-list ss))
  (initget "LD LU RD RU DL DR UL UR")
  (setq tw (getkword "\n[Index:/LD/LU/RD/RU/DL/DR/UL/UR]:"))
  (cond
    ((or (= tw "LD")(= tw "LU"))   
      (setq ll (sortx+ ll))
      (if (= tw "LD")(setq ll (sorty+ ll))(setq ll (sorty- ll)) )
    )
    ((or (= tw "RD")(= tw "RU"))   
      (setq ll (sortx- ll))
      (if (= tw "RD")(setq ll (sorty+ ll))(setq ll (sorty- ll)) )
    )
    ((or (= tw "DL")(= tw "DR"))   
      (setq ll (sorty+ ll))
      (if (= tw "DL")(setq ll (sortx+ ll))(setq ll (sortx- ll)) )
    )
   ((or (= tw "UL")(= tw "UR"))   
      (setq ll (sorty- ll))
      (if (= tw "UL")(setq ll (sortx+ ll))(setq ll (sortx- ll)) )
    )
  )
  (setq sn (getint "\nStart Number <1>:"))
  (setq in (getint "\nIncrement <1>:"))
  (if sn nil (setq sn 1))
  (if in nil (setq in 1))
  (foreach i ll
    (setq obj (vlax-ename->vla-object i))
    (vla-put-textstring obj (itoa sn))
    (setq sn (+ sn in))
  )
)
;
(defun sortx+ (lst)
  (setq lst (vl-sort lst '(lambda (p1 p2)(< (car (cdr (assoc 10 (entget p1))))
                                              (car (cdr (assoc 10 (entget p2))))))))
)
(defun sortx- (lst)
  (setq lst (vl-sort lst '(lambda (p1 p2)(> (car (cdr (assoc 10 (entget p1))))
                                              (car (cdr (assoc 10 (entget p2))))))))
)
(defun sorty+ (lst)
  (setq lst (vl-sort lst '(lambda (p1 p2)(< (cadr (cdr (assoc 10 (entget p1))))
                                              (cadr (cdr (assoc 10 (entget p2))))))))
)
(defun sorty- (lst)
  (setq lst (vl-sort lst '(lambda (p1 p2)(> (cadr (cdr (assoc 10 (entget p1))))
                                              (cadr (cdr (assoc 10 (entget p2))))))))
)
[/PHP]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2004-12-8 10:59:34 | 显示全部楼层
  功能不错,可以以此为模板再扩展。应该增加对含有前后缀序号的处理(例如L-1a等),如果仅仅是数字,用途不大。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-12-15 23:16:41 | 显示全部楼层
“LD LU RD RU DL DR UL UR"可以解释一下吗
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-12-17 13:50:48 | 显示全部楼层
由 initget 所建立的控制标志及关键字表皆会应用到跟随其后的 entsel , nentsel, nentselp或getxxx调用, 接着便自动抛弃。这样可避免需再调用其他函数来清除此特定状况。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

已领礼包: 25个

财富等级: 恭喜发财

发表于 2004-12-19 14:52:26 | 显示全部楼层
我也和2楼的观点一样, 希望楼主能加入前缀和后缀的功能
在画平面布置图时用于给构件编号
主要用在结构平面布置图中, 这是一个非常有用的功能
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-12-19 16:05:10 | 显示全部楼层
Index:/LD/LU/RD/RU/DL/DR/UL/UR]:指的是什么?
还有就是使用过程中会出现不规则的排列,如4、5、6、7、1、2、3,为什么呢?
由于不会做演示,只能这样描述了。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-12-20 10:50:03 | 显示全部楼层
我的也是,比如:1 1 1 1 1
首数为3,增量为1,排序后会变成5 6 7 3 4
而不是我想要的3 4 5 6 7
而ET工具中的编号程序不会发生这种情况。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-1-26 16:36:09 | 显示全部楼层
这个程序我想了很久了。
刚才看了eachy斑竹的eanum程序,实现了处理前缀的功能,但我想要框选的。
请长老再改进一下吧。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-1-31 12:50:25 | 显示全部楼层
我喜欢序号后还跟着一串文字
这样的序号不知能不来改
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-24 09:55 , Processed in 0.402619 second(s), 49 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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