2009-01-28 59 views
22

我想在我的代码中调用一个windows程序,并在代码本身中确定参数。如何使用参数调用外部程序?

我不想调用外部函数或方法,而是在WinXP环境中的实际.exe或批处理/脚本文件。 C或C++将成为首选语言,但如果这更容易在任何其他语言中完成,请让我知道(ASM,C#,Python等)。

回答

23

当你调用CreateProcess的(),系统()等,确保您的双引号的文件名字符串(包括命令程序文件名),以防文件名和/或完全限定路径有空格,否则文件名路径的各部分将被命令解释器解析为单独的参数。

system("\"d:some path\\program.exe\" \"d:\\other path\\file name.ext\""); 

对于Windows,建议使用CreateProcess()。它具有更加复杂的设置,但您可以更好地控制流程的启动方式(如Greg Hewgill所述)。对于快速和肮脏,你也可以使用WinExec()。 (system()可移植到UNIX)。

启动批处理文件时,您可能需要使用cmd.exe(或command.com)启动。

WinExec("cmd \"d:some path\\program.bat\" \"d:\\other path\\file name.ext\"",SW_SHOW_MINIMIZED); 

(或SW_SHOW_NORMAL如果您希望显示命令窗口)。

Windows应该在系统PATH中找到command.com或cmd.exe,因此不需要完全限定,但是如果您想确定可以使用CSIDL_SYSTEM来编写完全限定的文件名(不要简单地使用C:\ Windows \ system32 \ cmd.exe)。

+1

这些是可能的未来障碍和一般澄清的精彩提示。非常感谢。 – Will 2009-01-28 05:14:41

8

我想你正在寻找Windows API中的CreateProcess函数。实际上有一系列相关的电话,但这会让你开始。这很容易。

+1

好吧,它不像使用system()那么简单,但至少存在这样的解决方案!感谢最强烈的建议和链接。 – Will 2009-01-28 05:19:35

5

最简单的方法之一是使用运行时库函数system()。它只需要一个字符串作为参数(参数比CreateProcess少很多!)并执行它就好像它是在命令行上键入的一样。 system()也会在返回之前自动等待该过程完成。

也有局限性:

  • 你必须在启动过程的标准输入和标准输出较少的控制
  • 而另一个进程正在运行,你不能做任何事情(比如决定将其杀死)
  • 你不能得到一个处理其他进程,以便查询以任何方式

运行时库还提供了exec*一个有趣的家庭(execl,execlp,execle,execv, execvp,或多或少),它们源自Unix遗产并提供对该过程的更多控制。

在Win32的最低级别,所有进程都由CreateProcess函数启动,这为您提供了最大的灵活性。

+0

这绝对是我以为我在寻找......但这些限制很难通过......我可能会这样做,如果设计将与它一起工作。感谢这个信息! – Will 2009-01-28 05:12:24

8

C++例如:

char temp[512]; 
sprintf(temp, "command -%s -%s", parameter1, parameter2); 
system((char *)temp); 

C#示例:

private static void RunCommandExample() 
    { 
     // Don't forget using System.Diagnostics 
     Process myProcess = new Process(); 

     try 
     { 
      myProcess.StartInfo.FileName = "executabletorun.exe"; 

      //Do not receive an event when the process exits. 
      myProcess.EnableRaisingEvents = false; 

      // Parameters 
      myProcess.StartInfo.Arguments = "/user testuser /otherparam ok"; 

      // Modify the following to hide/show the window 
      myProcess.StartInfo.CreateNoWindow = false; 
      myProcess.StartInfo.UseShellExecute = true; 
      myProcess.StartInfo.WindowStyle = ProcessWindowStyle.Maximized; 

      myProcess.Start(); 

     } 
     catch (Exception e) 
     { 
      // Handle error here 
     } 
    } 
+0

很好的例子,谢谢! – Will 2009-01-28 05:22:04