使用forfiles和7zip的文件名中的空格

问题描述 投票:4回答:3

我正在编写一个脚本来压缩旧文件,使用forfiles进行循环,使用7za进行压缩。我一直在努力解决如何处理文件名中的空格,虽然我找到了一个似乎有效的解决方案,但不明白为什么让我担心将其部署到生产环境中。

以下是似乎有效的命令:

forfiles -p%rootLogDir% -s -m*.log -d-14 -c"cmd /c 7za a -tzip """@PATH\@FILE-%date%.zip""" """@PATH\@FILE""""

请注意,7za的路径和文件名参数在它们周围有3组(是三组)引号。一组引号什么都不做,两组引号导致脚本将目录中的每个文件添加到归档中,而不是指定的那个,并且三个似乎起作用。

任何人都可以解释为什么需要这么多?我原本以为在一套之后剩下的都是多余的,但显然我错了。

windows command-line cmd space 7zip
3个回答
2
投票

forfiles是一个cmd.exe子命令?如果是这样,你应该用许多(MS)windows标签中的一个重新标记你的问题。)

即使对于在shell和bat脚本方面有丰富经验的人来说,引用也是令人抓狂的经历。

@ BugFinder的msg是合适的,我想补充说3个双引号是“引用”单个双引号char的一种方式。

您正在使用命令处理器(cmd.exe?)。键入命令(包含1个或多个单词或运算符),即

myCommand /s /d %dir% file1 file2 > sumFile

然后按Enter键。命令处理器不仅会开始执行您提交的命令,还会扫描该行,查找特殊大小写字符和符号,如变量名称。在Unix shell中,环境变量看起来像$varName${varName}。在.bat文件%var%%%v%%。该变量必须转换为值。

这只是命令处理器制作的一个传递,还有其他传递。但是根据您的需要,cmd处理器正在扫描应该作为一个单词的单词集。如果你有一个var="one two",不用引号围绕值侧会混淆任何必须处理它的命令。它看起来像var=one .... two(单独的单词,对吧?)。

因此,如果由于某种原因你需要通过双引号char传递给较低的处理层,你必须遵循命令处理器规则,根据需要引用一些东西然后一切都会正常工作。

就像“单词”是引用的单词一样,"""是引用的双引号。在命令处理器正常处理引号之后,中间双引号仍将保留在命令行的命令处理器的“视图”中(在变量扩展之后,处理规则的所有其他顺序都已经过紧随其后。)

呼!

所以要把它包起来,你在评论中写道

但随后""" - > "" - > "

Of,z zxsw = => z z x swい

那么为什么一个引用不够呢?

因为使用"""是让命令处理器留下一个独立的双引号字符的一种方法,保留在命令行上而不会爆炸。

或者第一个浓缩双引号是否获得某种神奇的力量?

没有神奇的力量,请注意你的命令有一个后来的"s。每组都留下1个""" char供以后处理。

正如@BugFinder指出的那样,"""可能就足够了,但我不确定你使用的是哪个命令处理器或shell,所以我无法运行测试。

最后,根据belisarius写的一个很好的提醒,

请允许我欢迎您访问StackOverflow并提醒我们通常在这里做的三件事:1)当您收到帮助时,请尝试给予它,回答您在专业领域的问题2)阅读常见问题解答,",3)当您看到好的时候问答,使用灰色三角形\"投票,因为系统的可信度是基于用户通过分享他们的知识而获得的声誉。还记得通过按复选标记http://tinyurl.com/2vycnvr接受更好地解决问题的答案(如果有的话)

我希望这有帮助。


1
投票

快速猜测,就像许多事情“”“=”,例如2引号围绕引号......“也可能已经足够了。”


0
投票

必须引用包含空格的所有文件名和路径。

接下来,关于你的问题,如何说明如下路径:

http://i.stack.imgur.com/kygEP.png
© www.soinside.com 2019 - 2024. All rights reserved.