找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2444|回复: 6

[LISP函数]:创建目录,包括子目录

[复制链接]
发表于 2005-10-5 13:54:12 | 显示全部楼层 |阅读模式

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

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

×
  1. (defun string-break (str pat / i j lst)
  2.   (setq i 0)
  3.   (while (setq j (vl-string-search pat str i))
  4.     (setq lst (cons (substr str (1+ i) (- j i)) lst))
  5.     (setq i (+ j (strlen pat)))
  6.   )
  7.   (mapcar (function (lambda (x) (vl-string-trim " " x)))
  8.           (cons (substr str (1+ i)) lst)
  9.   )
  10. )

  11. (defun string-right-trim (cSet string /)
  12.   (substr string 1 (vl-string-search cSet string))
  13. )

  14. (defun dir-tree        (path / path0 path1 f lst pat)
  15.   (setq path0 path)
  16.   (setq path1 path)
  17.   (setq f nil)

  18.   ;; break the path
  19.   (if (setq lst
  20.              (cond
  21.                ((vl-string-search (setq pat "\") path)
  22.                 (string-break path pat)
  23.                )
  24.                ((vl-string-search (setq pat "/") path)
  25.                 (string-break path pat)
  26.                )
  27.              )
  28.       )
  29.     (progn

  30.       ;; remove the last element from the list
  31.       (if (or (vl-string-search ":" (last lst)) (= "" (last lst)))
  32.         (progn (setq f t)
  33.                (setq lst (vl-remove (last lst) lst))
  34.         )
  35.       )

  36.       ;; make the tree
  37.       (setq lst
  38.              (append
  39.                (reverse
  40.                  (mapcar
  41.                    (function
  42.                      (lambda (i)
  43.                        (setq path0 (string-right-trim i path0))
  44.                      )
  45.                    )
  46.                    (mapcar (function (lambda (str) (strcat pat str)))
  47.                            lst
  48.                    )
  49.                  )
  50.                )
  51.                (list path1)
  52.              )
  53.       )

  54.       (if f
  55.         (vl-remove (car lst) lst)
  56.       )
  57.     )
  58.   )
  59. )
  60. (defun mk-dir (path /)
  61.   (vl-every 'vl-mkdir (dir-tree path))
  62. )
  63. (princ)

例如
(mk-dir  "C:\\a\\b\\c\\d\\e")
如已有部分目录存在则不创建
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2005-10-6 11:57:54 | 显示全部楼层
如果不在乎闪一下的话:
(command "shell" "md c:\\aaa\\bbb")

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

使用道具 举报

发表于 2005-10-6 13:18:53 | 显示全部楼层
(defun tt(str / re)
  (setq path(zfl-str-parse str "\\") m (car path))
  (foreach n (cdr path)
    (setq m (strcat m "\\" n))
    (vl-mkdir m)
    )
  )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

已领礼包: 221个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 2155个

财富等级: 金玉满堂

发表于 2014-1-19 15:19:48 | 显示全部楼层
vl-mkdir一次只能创建一级目录,
直接用这个(vl-mkdir "c:\\aaa\\ddd"),不能创建
3楼的缺了zfl-str-parse函数
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 305个

财富等级: 日进斗金

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-5 23:15 , Processed in 0.468898 second(s), 43 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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