scala调用系统-scala.sys.process使用
简介
scala.sys.process
提供了shell的和系统交互的DSL,包括执行命令, 逻辑操作, 重定向, 管道等操作。
启动流程
要执行与ProcessBuilder关联的所有外部命令,scala.sys.process提供了四组方法中。 这些方法中的每一种都具有各种过载和变化,以实现对I/O的进一步控制。
这四种方法如下:
- run:最通用的方法,它立即返回一个scala.sys.process.Process,并且外部命令同时执行。
"find /tmp -name *.jar".run()
- !:阻塞,直到所有外部命令退出,并返回执行链中最后一个的退出代码
"find /tmp -name *.jar" ! 如果没有参数,直接输出到标准输出或者标准错误输出. 同时可以传递Logger参数给!. import scala.sys.process._
var normalLines =
var errorLines =
val countLogger = ProcessLogger(line => normalLines += ,line => errorLines += )
"find /etc" ! countLogger
保存到变量中(返回最后命令运行的状态)
val result: Int = "find /tmp -name *.jar" !
- !!:阻塞直到所有外部命令都退出,并返回一个生成输出的String。
"find project -name *.jar".!!
保存到变量中(保存输出内容)
val result :String = "find project -name *.jar" !!
- lineStream:像run一样立即返回,生成的输出通过Stream [String]提供。
获取该流的下一个元素可能会阻塞,直到它变为可用。 如果返回码不为零,此方法将抛出异常
val contents: Stream[String] = Process("ls").lineStream
注:如果不需要,请使用lineStream_! 方法。
val etcFiles = "find /etc" lines_! ProcessLogger(line => ())
处理输入和输出
- 如果未指定,则使用run或!执行外部命令的输入。 不会绑定任何东西,输出将被重定向到Scala进程的stdout和stderr。
- 对于方法!! 和lines,不提供输入,输出将根据这些方法的语义进行定向。
Combining ProcessBuilder
这些ProcessBuilder以三种不同的方式组合。
- #| 将第一个命令的输出传递给第二个命令的输入。 它镜像一个shell管(|)
- #&& 有条件地执行第二个命令,如果前一个命令以退出值0结束。它镜像shell的&&
- #|| 如果前一个命令的退出值不为零,则有条件地执行第三个命令。 它镜像shell的||
例如:
它们可以并行执行,第一个输出作为输入提供给第二个,就像Unix管道一样。 这是通过#|实现的方法。
"ls" #| "grep linux"
它们可以按顺序执行,第二次结束后第二次启动。 这是通过###方法完成的。
"ls" ### "grep linux"
第二个的执行可以通过第一个的返回代码(退出状态)来调节,或者仅在它为零时,或者仅在它不为零时。 方法 #&& 和 #|| 完成这些任务
import scala.sys.process._
"find src -name *.scala -exec grep null {} ;" #| "xargs test -z" #&& "echo null-free" #|| "echo null detected" !
重定向
scala的重定向不仅可以从定向普通的文件,还可以把网络上的文件进行重定向到本地:
a #< url or url #> a
例子:
url("http://fuliang.iteye.com") #> file("blog.html") !
或者
file("blog.html") #< url("http://fuliang.iteye.com") !
注: 示例中的url和file均需进行封装,具体如下:
new java.net.URL("http://www.baidu.com") #> new java.io.File("/tmp/baidu.html") !
注意,重定向必须用 new java.io.File("")封装,否则会当作命令,比如"ls" #> "/tmp/a" !将会出错,必须scala> "ls" #> new java.io.File("/tmp/a") !
文件:
a #< file or file #> a
a可以是一个文件或者一个命令,比如:
file("blog.html") #> file("fuliang_blog.html") !
或者
file("fuliang_blog.html") #< file("blog.html") !
追加操作 #>>, #<<
a #>> file or file #<<
url("http://fuliang.iteye.com") #> "grep -i ruby" #>> file("Ruby") !
或者
file("Ruby") #<< ( "grep ruby" #< url(http://fuliang.iteye.com") ) !
与cat一起使用
val spde = url("http://technically.us/spde/About")
val dispatch = url("http://databinder.net/dispatch/About")
val build = file("project/build.properties")
cat(spde, dispatch, build) #| "grep -i scala" !
最后:! 最后执行命令,并返回退出值。 无论打印什么都将发送到Scala过程标准输出。 如果我们想捕捉它,我们可以用 !! 代替
注意:lines方法虽然已弃用,但可能与同名的StringLike方法冲突。 为避免这种情况,可能希望在进程中调用构建器而不是导入scala.sys.process._。 上面的例子是
import scala.sys.process.Process
Process("find src -name *.scala -exec grep null {} ;") #| Process("xargs test -z") #&& Process("echo null-free") #|| Process("echo null detected") !
scala调用系统-scala.sys.process使用的更多相关文章
- scala调用外部命令
scala调用外部命令 1. 导入sys.process包 2. 调用方式:" 外部命令 " ! 双引号内+外部命令+感叹号 例: scala调用外部命令工作原 ...
- scala调用Linux命令行
在 scala 里面存在 调用 Linux 命令行的函数: import scala.sys.process._ 执行的方法也不难: import scala.sys.process._ /** * ...
- 系统模块 sys 函数的调用
系统模块 sys 运行时系统相关的信息 sys模块的数据 数据 描述 sys.path 模块搜索路径 path[0] 是当前脚本程序的路径名,否则为 '' sys.modules 已加载模块的字典 s ...
- [Scala] 快学Scala A1L1
基础 1.1 声明值和变量 在Scala中,鼓励使用val; 不需要给出值或变量的类型,这个信息可以从初始化表达式推断出来.在必要的时候,可以指定类型. 在Scala中,仅当同一行代码中存在多条语句时 ...
- Scala学习(一)--Scala基础学习
Scala基础学习 摘要: 在篇主要内容:如何把Scala当做工业级的便携计算器使用,如何用Scala处理数字以及其他算术操作.在这个过程中,我们将介绍一系列重要的Scala概念和惯用法.同时你还将学 ...
- Scala具体解释---------Scala是什么?可伸展的语言!
Scala是什么 Scala语言的名称来自于"可伸展的语言". 之所以这样命名,是由于他被设计成随着使用者的需求而成长.你能够把Scala应用在非常大范围的编程任务上.从写个小脚本 ...
- [Scala] java使用scala的jar包问题:Exception in thread "main" java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.Short
场景 刚写的scala处理bmp文件的实验, 打了jar包让java调用一下, 结果发生这个错误. package org.tanglizi.bmp.demo; import org.tanglizi ...
- java.lang.String cannot be cast to scala.runtime.Nothing Scala中的Nothing类型
经常在写Rdd的时候, 如: val OWNER_ID=row.getAs("OWNER_ID") 等, 运行是可能会报异常 : java.lang.String cannot ...
- Visual studio之C# 调用系统软键盘(外部"osk.exe")
背景 App需要调用系统软键盘输入数据,自己去实现软键盘有些复杂,现在又是急需,没时间去研究实现软键盘,所以只能调用系统软键盘. 正文 需要添加命名空间, using System.Diagnosti ...
随机推荐
- python读取excel保存到mysql
首先安装xlrd模块:pip install xlrd ,核心代码网上有很多,这里主要是关于一些个人实际碰到问题细节的处理 1.excel数据不规范导致读取的数据存在空白行和列: 2.参数化执行sql ...
- Ubuntu添加字体
在字体库下载打包好的字体: 方正字体全库:http://www.downza.cn/soft/8203.html 华文字体:http://www.onlinedown.net/soft/635126. ...
- 初识Flink-从WorldCount开始
Apache Flink是一个用于分布式流和批处理数据处理的开源平台.Flink的核心是流数据流引擎,为数据流上的分布式计算提供数据分发,通信和容错.Flink在流引擎之上构建批处理,覆盖本机迭代支持 ...
- React-Native初识-安卓篇(一)
前言:React-Native简称RN,可以用来构建Android和IOS的应用程序,在接下来的两个半月里,我会记录下本人在学习RN开发项目中的点滴. 本篇目录: 1.React-Native初识 2 ...
- js转换成布尔类型boolean
/** * js转换成布尔值 * a.转换方法:Boolean(var) * b.数字转换成布尔,除了0与NaN,其余都是true * c.字符串转换成布尔,除了空串"",其余都是 ...
- 利用Stream模式进行文件拷贝
const fs = require('fs'); const file = fs.createReadStream("readfile.js"); const outputFil ...
- 配置node 的路由
配置路由 引入路由中间件 const Router= require('koa-router'); 实例化 const router= new Router(); 配置路由地址 router.use( ...
- docker 安装 jenkins 笔记
前提: 已安装好 docker-ce,可运行 docker 命令 命令: sudo docker pull jenkins mkdir -p ~/dockers/jenkins cd ~/docker ...
- 安装JDK,并检测JDK是否安装成功
方法/步骤 首先,我们需要先安装好我们的JDK软件,安装好之后,我们需要对我们的电脑进行环境变量配置的设置,这样我们安装的JDK才能真正起到作用. 第一步:我们需要将光标放在“计算机”上面,然 ...
- Python的return语句中使用条件判断
if end1 <= val <= end2 or end2 <= val <= end1: return True else: return False 等于 return ...