【发布时间】:2015-05-26 14:21:16
【问题描述】:
我正在运行以下 bash 脚本
scrapy crawl flipkart -a key="$1" -o "$2"flipkart.xml
scrapy crawl myntra -a key="$1" -o "$2"myntra.xml
scrapy crawl jabong -a key="$1" -o "$2"jabong.xml
echo " scrapy completed"
通过终端执行的 bash 脚本按预期运行,因为它完成了一次 scrapy 命令的执行,然后是另一个,但是当我尝试通过 java 调用它时,相同的脚本不会执行 scrapy 命令。 它执行 shell 脚本,因为我能够通过 java 中的输入流读取回显数据。
String command = "/Users/renny/Documents/WorkSpaces/Scrapy/tutorial/tutorial/crawls.sh";
String[] cmd = new String[]{"/bin/sh", command,key,formattedDate};
//Process p = Runtime.getRuntime().exec(cmd);
ProcessBuilder p = new ProcessBuilder(cmd);
Process p2 = p.start();
InputStream error = p2.getErrorStream();
for (int i = 0; i < error.available(); i++) {
System.out.println("" + error.read());
}
BufferedReader br = new BufferedReader(new InputStreamReader(p2.getInputStream()));
String line;
System.out.println("Output of running " + command + " is: ");
请建议我如何确保scrapy命令被执行。
在一个批处理文件中,我认为我们可以调用 start 来确保命令在单独的提示符下运行,我可以在 bash 脚本中执行类似的操作
【问题讨论】:
-
您确定您的
PATH是正确的,这样可以找到scrapy吗?您从该命令尝试中得到什么标准错误? -
我会读取错误流并显示它。它可能包含未执行命令的原因。
-
我在运行命令时没有收到任何错误。我能够从能够运行scrapy命令的终端成功运行脚本文件。
-
我添加了以下代码来检查错误流 InputStream error = p2.getErrorStream(); for (int i = 0; i
-
这种读取错误流的方式并不可靠,因为它只打印调用时可用的字节。您应该以与读取“输入”流相同的方式执行此操作 - 使用
BufferedReader。
标签: java linux bash shell scrapy