0

我正在尝试从 java/tomcat6 webapp 调用 python 脚本。我目前正在使用以下代码:

           Process p = Runtime.getRuntime().exec("python <file.py>"); 
       InputStream in = p.getInputStream();
       InputStreamReader isr = new InputStreamReader(in); 
       BufferedReader b = new BufferedReader(isr);

       logger.info("PYTHON OUTPUT");


       String line = null;
       while ( (line = b.readLine()) != null){
            logger.info(line);
       }

       p.waitFor();
       logger.info("COMPLETE PYTHON OUTPUT");
       logger.info("EXIT VALUE: "+p.exitValue());

我真的看不到 python 脚本的 catalinia.out 文件中的任何输出,并且无法使用像 jython 这样的适配器库,因为该脚本依赖于几个需要 python 的 Numpy 模块才能工作的机器学习库。

帮助?

4

1 回答 1

1

解释可能是以下一项(或多项):

  • 该命令失败并将错误消息写入其“stderr”fd ...您没有查看。

  • 该命令无法启动,因为命令名称不正确;例如在 上找不到它$PATH

  • 该命令正在尝试从其stdinfd 中读取...但您尚未提供任何输入(还)。

  • 这可能是命令行拆分的问题;例如,如果您使用带有嵌入空格的路径名,或者其他通常由 shell 处理的东西。

此外,由于这是 python,这可能是特定于 python 的环境变量、当前目录和/或正在执行命令的有效用户的问题。


如何进行:

  1. 确定 python 命令是否实际启动。例如。“破解”“”以在启动时将内容写入临时文件。

  2. 改为使用ProcessBuilder创建Process对象。这将使您能够更好地控制流以及它们的处理方式。

  3. 找出子进程“stderr”的情况。(ProcessBuilder 允许您将其重定向到“stdout”...)

于 2013-07-20T00:04:53.110 回答