得到Ant构建错误:无法运行程序“python”

时间:2012-06-11 17:58:20

标签: java python apache ant

这是构建文件:

<exec executable="python" failonerror="true">
  <arg line="${installer.izpack.dir}/utils/wrappers/izpack2exe/izpack2exe.py"/>
  <arg line="--file=${basedir}/installer/EasyIT-installer.jar"/>
  <arg line="--output=${basedir}/installer/EasyIT-installer.exe"/>
  <arg line="--no-upx"/>
</exec>

输出:

BUILD FAILED
E:\Java Projects\Spark Projects\EastIT - Copy\build\build.xml:873: Execute failed: java.io.IOException: Cannot run program "python" (in directory "E:\Java Projects\Spark Projects\EastIT - Copy"): CreateProcess error=2, The system cannot find the file specified
        at java.lang.ProcessBuilder.start(ProcessBuilder.java:1029)
        at java.lang.Runtime.exec(Runtime.java:615)
        at org.apache.tools.ant.taskdefs.Execute$Java13CommandLauncher.exec(Execute.java:8 62)
        at org.apache.tools.ant.taskdefs.Execute.launch(Execute.java:481)
        at org.apache.tools.ant.taskdefs.Execute.execute(Execute.java:495)
        at org.apache.tools.ant.taskdefs.ExecTask.runExecute(ExecTask.java:631)
        at org.apache.tools.ant.taskdefs.ExecTask.runExec(ExecTask.java:672)
        at org.apache.tools.ant.taskdefs.ExecTask.execute(ExecTask.java:498)
        at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
        at sun.reflect.GeneratedMethodAccessor15.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.ja va:43)
        at java.lang.reflect.Method.invoke(Method.java:601)
        at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
        at org.apache.tools.ant.Task.perform(Task.java:348)
        at org.apache.tools.ant.Target.execute(Target.java:392)
        at org.apache.tools.ant.Target.performTasks(Target.java:413)
        at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1399)
        at org.apache.tools.ant.Project.executeTarget(Project.java:1368)
        at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java :41)
        at org.apache.tools.ant.Project.executeTargets(Project.java:1251)
        at org.apache.tools.ant.Main.runBuild(Main.java:811)
        at org.apache.tools.ant.Main.startAnt(Main.java:217)
        at org.apache.tools.ant.launch.Launcher.run(Launcher.java:280)
        at org.apache.tools.ant.launch.Launcher.main(Launcher.java:109)
Caused by: java.io.IOException: CreateProcess error=2, The system cannot find the file specified
        at java.lang.ProcessImpl.create(Native Method)
        at java.lang.ProcessImpl.<init>(ProcessImpl.java:189)
        at java.lang.ProcessImpl.start(ProcessImpl.java:133)
        at java.lang.ProcessBuilder.start(ProcessBuilder.java:1021)
        ... 23 more


Total time: 50 seconds

1 个答案:

答案 0 :(得分:10)

确保python位于正在运行构建的PATH中,或者在exec任务中指定python可执行文件的绝对路径。

有关使用Windows与非Windows的任何具体说明,请查看exec task的文档。请注意,那里提到了您的具体错误:

  

常见问题是PATH上没有可执行文件。如果您收到错误消息无法运行程序“...”:CreateProcess error = 2。该系统找不到指定的路径。看看你的PATH变量。只需在命令行上直接输入命令,如果Windows找到它,Ant也应该这样做。 (否则请在用户邮件列表上寻求帮助。)如果Windows无法执行程序,请将程序目录添加到PATH(设置PATH =%PATH%; dirOfProgram)或在构建文件的可执行属性中指定绝对路径。