0

我正在尝试通过 VBS 获取在 cmd vindow 中运行的命令。就像这个答案: How to keep the VBScript command window open during execution

我试图发出的命令是这样的,因为它在 .cmd 文件中工作。

"\Program Files (x86)\Microsoft SQL Server\120\DTS\Binn\dtexec" /x86 /f "\\path\folder\folder with space\Import.dtsx"

我一直无法让它以上述答案的语法工作:

objShell.run "%comspec% /c ""SomeProgram.exe -R & pause""", 1, True

认为这是一个双引号问题,但我找不到它。

(我必须使用 dtexec 的整个路径来强制使用 16 位版本。)

跟进:================================================== =======

这有效:

oShell.Run "%comspec% /C ""\Program Files (x86)\Microsoft SQL Server\120\DTS\Binn\dtexec"" /x86 /f c:\temp\Import.dtsx & Pause", 1, True

这不会:

oShell.Run "%comspec% /C ""\Program Files (x86)\Microsoft SQL Server\120\DTS\Binn\dtexec"" /x86 /f ""c:\temp\temp two\Import.dtsx"" & Pause", 1, True

也不是这个:

oShell.Run "%comspec% /C ""\Program Files (x86)\Microsoft SQL Server\120\DTS\Binn\dtexec /x86 /f c:\temp\temp two\Import.dtsx"" & Pause", 1, True

正是文件名参数中的那个空间正在填充它。

4

1 回答 1

1

您不需要pause,只需告诉 CMD 在命令完成后保持窗口打开(/k)而不是关闭它(/c):

objShell.Run "%comspec% /k program.exe -R", 1, True

仅当路径中包含空格时才需要嵌套双引号,例如:

objShell.Run "%comspec% /k ""C:\some folder\program.exe"" -R", 1, True

编辑:如果命令行中的参数也是带空格的路径,那么您需要在每个路径周围加上引号,并在整个语句周围加上另一组引号:

objShell.Run "%comspec% /c """"C:\some folder\program.exe"" /p ""foo bar"" & pause""", 1, True
于 2017-05-30T20:17:17.257 回答