明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2287|回复: 4

[求助]删除列表中的相同元素LstDelSame没作用?[自己解决了]

[复制链接]
发表于 2007-11-30 18:09:00 | 显示全部楼层 |阅读模式
本帖最后由 作者 于 2007-12-2 9:41:51 编辑

;;;----通用函数-----
;;选择集->图元名表
(defun ss->elst (ss / elst)
  (setq i 0)
  (repeat (sslength ss)
    (setq elst (cons (ssname ss i) elst)
   i    (1+ i)
    )
  )
  (reverse elst)
)

;;;删除列表中的相同元素(保留一个)并返回新表
(defun LstDelSame (lst / x nl)
  (foreach x lst
    (if (not (member x nl))
      (setq nl (cons x nl))
    )
  )
  (setq nl (reverse nl))
  nl
)

(defun c:tt (/ ELST O1 O2 P PLST PLST0 SS)
  (princ "\n选择所有的交线.")
  (setq ss (ssget (list (cons 0 "*POLYLINE,LINE"))))
  (setq elst (ss->elst ss))
  (foreach e elst
    (setq o1 (vlax-ename->vla-object e))
    (foreach e elst
      (setq o2 (vlax-ename->vla-object e))
      (setq p (vlax-invoke o1 'intersectwith o2 acextendnone))
      (setq plst0 (cons p plst0))
    )
  )
  (setq plst2 (vl-remove nil (LstDelSame plst0)))
)

得到((29.0888 21.4991 0.0) (33.789 15.9458 0.0) (29.0888 21.4991 0.0)
(33.789 15.9458 0.0))

得到的任意线的交点表,是有重复的点. LstDelSame 没作用...

----------------------------------------------------------------------------------------------------------

可是:

(LstDelSame '((29.0888 21.4991 0.0) (33.789 15.9458 0.0) (29.0888 21.4991 0.0)
(33.789 15.9458 0.0)))

得到((29.0888 21.4991 0.0) (33.789 15.9458 0.0)) 又是对的....

(setq aaa '((29.0888 21.4991 0.0) (33.789 15.9458 0.0) (29.0888 21.4991 0.0)
(33.789 15.9458 0.0)))

(LstDelSame aaa)

得到((29.0888 21.4991 0.0) (33.789 15.9458 0.0)) 也是对的....


"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2007-11-30 18:44:00 | 显示全部楼层

直接输入当然对了。

得到((29.0888 21.4991 0.0) (33.789 15.9458 0.0) (29.0888 21.4991 0.0)
(33.789 15.9458 0.0))

得到的任意线的交点表,是有重复的点. LstDelSame 没作用...

-》因为有微小误差,可能是点本身误差,也可能是浮点误差。如果不是完全相等,member是不起作用的。

虽然显示是(29.0888 21.4991 0.0) ,但可能是29.08883 只是cad显示不全,并不说明完全相等。

建议用equal,设定误差范围。

点评

可是你能告诉我精度的取值原则吗?  发表于 2011-11-30 00:25
 楼主| 发表于 2007-12-1 09:33:00 | 显示全部楼层

equal,版主说的,我想过了...

可是脑子转不过弯来...

那个坦白说,不会写...版主能直接帮忙把

http://bbs.mjtd.com/forum.php?mod=viewthread&tid=64501

这个主题的问题解决一下...谢谢....

发表于 2024-12-2 11:00:25 | 显示全部楼层
我也是这个问题,楼主解决了吗,重复的点干不掉啊
回复 支持 反对

使用道具 举报

发表于 2024-12-2 15:42:12 | 显示全部楼层
  1. (defun qly (point-list )
  2.   
  3.         
  4.         
  5.         
  6.         (setq new-list nil)
  7.   (foreach point point-list
  8.     (setq found nil)
  9.     (foreach new-point new-list
  10.       (if (< (distance point new-point) 1)
  11.         (setq found t)
  12.       )
  13.     )
  14.     (if (not found)
  15.       (setq new-list (cons point new-list))
  16.     )
  17.   )
  18.   (reverse new-list)
  19. )
回复 支持 反对

使用道具 举报

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

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2025-2-23 02:49 , Processed in 0.183533 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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