如何用ruby启动外部程序(如Excel表格),并在其执行或终止之前等待。
我知道可以使用以下代码启动Excel:
system 'start excel "my/path/to/the/sheet"'
但是使用这个只会开始表格然后继续。
你遇到的问题不是Ruby,而是启动命令,它会启动另一个程序并立即返回。你需要让该命令等待Excel完成使用 wait
标志:
system('start /wait excel "my/path/to/the/sheet"')
不要使用start命令!命令system会等待结果。在Windows提示符下,start命令会异步启动程序。
system 'excel yout/path/sheet'
%x{ ls }
system("notepad.exe")
在Ruby中另外一种方法是使用反引号。
`notepad.exe` # Same effect. Will also accept #{} variable insertion
start excel path\to\sheet
可以打开Excel,但只有excel path\to\sheet
是不行的。您将收到一个关于"excel"不是一个已识别的内部或外部命令的错误。修复此问题的方法是将Excel路径添加到您的环境变量中,或在您的system()
调用中包含Excel路径。EXCEL = File.join("C:", "Program Files",
"Microsoft Office", "OFFICE11", "excel.exe")
`"#{EXCEL}" "path\to\sheet"`
(在这里使用反引号只是我的个人喜好。我喜欢它,因为它可以插入变量。) 这将打开一个 Excel 实例,Ruby 脚本将等待应用程序终止。