在Scala中调用外部命令作为子进程
发布时间:2020-12-16 09:52:26 所属栏目:安全 来源:网络整理
导读:在 Python中,如果我想将外部命令作为子进程调用,我会执行以下操作: from subprocess import Popen,PIPEcmd = ['cat','-be']out,err = Popen(cmd,stdin=PIPE,stdout=PIPE,stderr=PIPE).communicate("some input") 在Scala中执行相同操作的标准方法是什么?使
|
在
Python中,如果我想将外部命令作为子进程调用,我会执行以下操作:
from subprocess import Popen,PIPE
cmd = ['cat','-be']
out,err = Popen(cmd,stdin=PIPE,stdout=PIPE,stderr=PIPE).communicate("some input")
在Scala中执行相同操作的标准方法是什么?使用Java的ProcessBuilder我提出了以下内容,但它非常难看: def communicate(cmd: List[String],input: Option[String] = None): (String,String) = {
val command = new java.util.ArrayList[String]()
cmd.foreach(command.add(_))
val builder = new ProcessBuilder(command)
val process = builder.start()
val stdinWriter = new java.io.PrintWriter((new java.io.OutputStreamWriter(new java.io.BufferedOutputStream(process.getOutputStream()))),true);
val stdoutReader = new java.io.BufferedReader(new java.io.InputStreamReader(process.getInputStream()))
val stderrReader = new java.io.BufferedReader(new java.io.InputStreamReader(process.getErrorStream()))
input.foreach(stdinWriter.write(_))
stdinWriter.close()
def read(reader: java.io.BufferedReader): String = {
val out = new ListBuffer[String]
var line: String = reader.readLine()
while (line != null) {
out += line
line = reader.readLine()
}
return out.result.mkString("n")
}
val stdout = read(stdoutReader)
val stderr = read(stderrReader)
stdoutReader.close()
stderrReader.close()
return (stdout,stderr)
}
val (catout,caterr) = communicate(List("cat","-be"),Some("some input"))
val (pwdout,pwderr) = communicate(List("pwd"))
Scala中是否有更好的替代品? 解决方法
这里的答案
How does the “scala.sys.process” from Scala 2.9 work?显示了如何使用新的Scala 2.9 scala.sys.process.Process.如果你不使用2.9,你可以使用sbt的过程部分; Scala进程源自哪个.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
