找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 962|回复: 1

[LISP函数]:保留列表的第m~n项

[复制链接]

已领礼包: 2个

财富等级: 恭喜发财

发表于 2007-12-27 11:29:29 | 显示全部楼层 |阅读模式

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

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

×
http://www.xdcad.net/forum/showthread.php?s=&threadid=642680

  1.   [FONT=courier new]
  2. (defun th-del-lst>mn< (m n lst / j)    ; 保留列表的第m~n项
  3.   (setq j -1)
  4.   (th-remove-if-not '(lambda (x)
  5.                        (and
  6.                          (setq j (1+ j))
  7.                          (<= m j)
  8.                          (>= n j)
  9.                        )
  10.                      ) lst
  11.   )
  12. )
  13. ;;; 命令: (setq lst (list 1 2 3 4 5 6 7 8 9 8 7 6 5 4 3 2 1))
  14. ;;; (1 2 3 4 5 6 7 8 9 8 7 6 5 4 3 2 1)
  15. ;;; 命令: (th-del-lst>mn< 3 6 lst)
  16. ;;; (4 5 6 7)
  17.   [/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2008-1-1 07:08:05 | 显示全部楼层

  1. (defun fr-del-lst>mn< (m n lst / j l)
  2.   (setq j 0 tf t)
  3.   (while (and tf lst)
  4.     (if        (and (>= j m)
  5.              (<= j n)
  6.         )
  7.       (setq l (cons (car lst) l))
  8.     )
  9.     (setq lst (cdr lst)
  10.           j   (1+ j)
  11.     )
  12.     (if (> j n) (setq tf nil))
  13.   )
  14.   (reverse l)
  15. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 05:45 , Processed in 0.212549 second(s), 34 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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