我已经创建了一个shell脚本,其中包含一个简单的语句unzip -o $1,在运行终端并将一个.zip文件作为参数传递时,它工作得很好,使用5第二步来创建解压缩的folder.Now,我尝试在scala中做同样的事情,我的代码如下所示:
object ZipExt extends App {
val process = Runtime.getRuntime.exec(Array[String]("/home/administrator/test.sh", "/home/administrator/MyZipFile_0.8.6.3.zip"))
process.waitFor
println("done")
}现在,每当我试图执行ZipExt时,它就会永远停留在process.waitFor中,无法到达print语句,我也尝试过在本地和服务器上使用这段代码。我尝试了其他可能的方法,比如在shell脚本中创建局部变量(包括shell脚本中的exit语句),尝试解压缩除mines之外的其他.zip,甚至有时执行print语句,但没有在那里创建解压缩文件。因此,我很确定,以编程方式执行unzip命令解压缩文件是有问题的,或者有其他方法可以编程解压缩压缩文件,我已经被这个问题困扰了大约两天,所以有人帮了忙。
发布于 2015-12-04 15:11:38
你给我们的信息似乎不足以重现这个问题:
% mkdir 34088099
% cd 34088099
% mkdir junk
% touch junk/a junk/b junk/c
% zip -r junk.zip junk
updating: junk/ (stored 0%)
adding: junk/a (stored 0%)
adding: junk/b (stored 0%)
adding: junk/c (stored 0%)
% rm -r junk
% echo 'unzip -o $1' > test.sh
% chmod +x test.sh
% scala
Welcome to Scala version 2.11.7 (Java HotSpot(TM) 64-Bit Server VM, Java 1.8.0_66).
Type in expressions to have them evaluated.
Type :help for more information.
scala> val process = Runtime.getRuntime.exec(Array[String]("./test.sh", "junk.zip"))
process: Process = java.lang.UNIXProcess@35432107
scala> process.waitFor
res0: Int = 0
scala> :quit
% ls junk
a b c我建议在你自己的机器上尝试同样的复制。如果它对你也成功了,那么就开始系统地减少后续案例和失败案例之间的差异,一步一步。这将有助于缩小可能的原因。
https://stackoverflow.com/questions/34088099
复制相似问题