中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net 论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

中国DOS联盟论坛
现在时间是 2026-06-13 21:04
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » [讨论]FOR的命令行分析机制
楼 主 [讨论]FOR的命令行分析机制 发表于 2006-06-22 19:11 ·  中国 山西 大同 中移铁通
元老会员
★★★★
Batchinger
积分 4,432
发帖 1,512
注册 2002-10-18 00:00
UID 19
性别 男
状态 离线
To All:

FOR的命令行分析机制是很复杂,有很多可以讨论的细节,这里首先讨论的是容易惹人疑窦的遍历集合(也就是in后do前括号中的部分)的分析机制。

在此之前,首先提出一个应用上的实际问题。严格的说,这不能算是FOR的一个BUG,而是对旧有语法特性的沿袭不当。

关于FOR的旧有语法特性, 中曾有讨论,现略作整理和补充:

1、IN语句后()中内容被称为FOR的遍历集合,其中可以包含多个元素,每个元素之间以空格、分号、等号等参数分隔符分隔。FOR将按以下过程一一处理所有的元素。

2、如果元素中含有文件名通配符(星号或问号),则FOR将此元素理解为文件名,它将在当前路径或者元素中所指定的路径下寻找可以对应的文件。如果找到,则用其文件名逐个替换并执行DO后的语句;如果未找到,则不执行DO后的语句,也不作任何提示。

3、如果元素中不含有文件名通配符,则FOR则将其理解为普通意义的字符串,替换并执行DO后的语句。

4、在文件名的替换过程中,如果元素中指定了路径,那么其替换后的FOR变量中也将包含同样的路径,反之亦然。

5、在MSDOS6及其以下版本中,不支持长文件名,因此也不支持引号包含的文件名,所以在遍历元素中同时使用引号和通配符时,将没有任何执行结果。

简而言之,如果有通配符则进行文件名的替换,否则进行字符串的替换。

在后来的MSDOS7.10/COMMAND@Win9x/CMD@WinNT中,这个特性继续保留,只是在此基础上增加了对含引号文件名的识别和分析。

至于在FOR/R和FOR/D仍然为何仍然沿袭这个特性,这确实是个值得讨论的问题,因为绝大多数情况下,我们使用FOR/R或FOR/D的目的,都是要进行文件或目录名的替换,而非普通文本的替换。

但显然,FOR命令的设计思路与我们是有分歧的,且翻阅一下FOR的命令行帮助信息。此时,我们可以揣测一下这个设计思路是什么:FOR/D只是将文件名匹配切换为目录名匹配,FOR/R只是将指定目录的匹配切换为指定目录树的匹配,这均不会也不该影响文件名和字符串的匹配选择。这样的设计,使程序的改动尽可能的小,至少遍历集合分析的代码不需要太大的改动。

然而,会有多少人知道并理解这个特性呢?

FOR/R syntax bug
http://groups.google.com/group/alt.msdos.batch.nt/browse_thread/thread/84b80fadc616f74a/

E:\>dir/s/b
File Not Found

E:\>md test

E:\>echo test>test\x.txt

E:\>for /r %f in (x.txt) do @echo %f
E:\x.txt
E:\test\x.txt

E:\>for /r %f in (x.txt*) do @echo %f
E:\test\x.txt


运行XMSDSK 后,在他的虚拟盘目录下,循环FOR就不支持*统配符了?
http://www.cn-dos.net/forum/viewthread.php?tid=15744

FOR /? in CMD@WinXP

FOR /D %variable IN (set) DO command

如果集中包含通配符,则指定与目录名匹配,而不与文件
名匹配。

FOR /R path] %variable IN (set) DO command

检查以 path 为根的目录树,指向每个目录中的
FOR 语句。如果在 /R 后没有指定目录,则使用当前
目录。如果集仅为一个单点(.)字符,则枚举该目录树。
※ Batchinger 致 Bat Fans:请访问 批处理编程的异类 ,欢迎交流与共享批处理编程心得!
2 发表于 2006-06-23 23:48 ·  中国 广东 广州 天河区 电信
荣誉版主
★★★
积分 718
发帖 313
注册 2005-09-26 00:00
UID 42844
性别 男
状态 离线
看过很多FOR 的应用,不在于对目录的遍历,而更多的是使用FOR来解析.所以我猜测是因此而没有多少人知道并理解你所说的这个特性.

[ Last edited by 220110 on 2006-6-23 at 23:52 ]
3 发表于 2006-06-24 18:19 ·  中国 上海 长宁区 电信
中级用户
★★
论坛第一菜鸟
积分 361
发帖 166
注册 2006-04-15 13:23
UID 53870
状态 离线
是不是 FOR IN DO 要大写啊
Diskette Operating System
4 发表于 2007-01-17 05:34 ·  中国 山东 济南 电信
社区乞丐
★★
此图片另存后死机
积分 -49
发帖 90
注册 2006-12-02 13:00
UID 72412
性别 男
状态 离线
可惜我来的时候willsort大师已经走了....

个人感觉/R 与 /D 参数 完全可以被/F 和无参数取代.
我的网络笔记本.非联系本人请勿访问!http://w.vicp.net
5 发表于 2007-01-17 06:58 ·  中国 江西 景德镇 电信
初级用户
积分 77
发帖 34
注册 2007-01-11 04:58
UID 76137
性别 男
来自 景德镇
状态 离线
支持2楼的说法!!
我喜欢,我选择。。
6 发表于 2007-03-16 07:50 ·  中国 湖北 武汉 江夏区 电信
初级用户
积分 76
发帖 38
注册 2007-03-13 02:54
UID 81544
性别 男
状态 离线
支持
7 发表于 2007-03-16 08:09 ·  中国 广东 广州 番禺区 电信
中级用户
★★
脚本爱好者
积分 238
发帖 93
注册 2007-03-11 13:38
UID 81417
性别 男
来自 GZ
状态 离线
for in do 的功能太大了,有望批处理高手们多谈谈这方面的应用,使我们这些批处理新手从中获益。多谢。
8 发表于 2007-03-18 03:40 ·  中国 上海 黄浦区 电信
初级用户
积分 49
发帖 22
注册 2005-08-04 13:44
UID 41332
性别 男
状态 离线
学习学习
9 发表于 2007-03-22 08:28 ·  中国 广西 梧州 电信
新手上路
积分 4
发帖 2
注册 2007-01-09 08:32
UID 75933
性别 男
状态 离线
谢谢楼主的分享了
10 发表于 2007-03-28 22:07 ·  中国 湖南 长沙 联通
社区乞丐
★★
gaoshou
积分 -16
发帖 77
注册 2007-01-30 09:11
UID 78105
性别 男
状态 离线
谢谢
:cool:
11 发表于 2007-03-29 05:03 ·  中国 湖北 武汉 电信
中级用户
★★
scriptlover
积分 328
发帖 131
注册 2007-03-25 22:17
UID 82910
性别 男
状态 离线
真强大,我一定要学会运用
12 发表于 2007-03-29 05:56 ·  中国 上海 电信
初级用户
积分 45
发帖 21
注册 2007-03-14 23:10
UID 81739
性别 男
状态 离线
学习了

大师 你很了不起!
13 发表于 2007-04-20 05:37 ·  中国 辽宁 大连 联通
初级用户
积分 70
发帖 38
注册 2007-03-24 09:25
UID 82762
性别 男
状态 离线
学习 学习 再学习~~~
14 发表于 2007-05-17 15:49 ·  中国 广东 深圳 联通
新手上路
积分 16
发帖 7
注册 2006-09-29 02:27
UID 63994
性别 男
来自 河南省南阳市
状态 离线
复制学习了..好东西呀..
15 发表于 2007-05-17 22:44 ·  中国 河南 郑州 联通
初级用户
积分 91
发帖 45
注册 2007-03-14 07:04
UID 81689
性别 男
状态 离线
看了都有点迷了..
论坛跳转: