使用SBT构建Scala项目

既然决定要在Scala上下功夫,那就要下的彻底。我们入乡随俗,学一下SBT。sbt使用ivy作为库管理工具。ivy默认把library repository建在user home下面。

安装SBT

在SBT的官网(http://www.scala-sbt.org/)下载相应版本的SBT。

Windows环境下建议配置SBT的环境变量。(windows上搞开发真是越发蛋疼。)具体步骤不说了,就是把sbt/bin目录配置进PATH。

在sbt/bin下有个sbt.bat,查看该bat文件。可以了解到该文件依赖于conf/sbtconfig.txt。

在conf/sbtconfig.txt中添加:

-Dfile.encoding=UTF8

-Dsbt.boot.directory=d:/sbt-repository/boot/

-Dsbt.ivy.home=d:/sbt-repository/

说明:

-Dsbt.boot.directory

-Dsbt.ivy.home

这两个是配置sbt.boot目录和ivy.home目录,用于缓存的jar包等信息存放位置。默认情况下jar包等信息存放于user home目录。

另外运行sbt的一下JVM参数也可以在sbtconfig.txt中指定。

SBT命令行环境

在命令行中进入工程目录,输入sbt,进入sbt的命令行。(这里建议进入工程目录再运行sbt命令。)

注意:第一次使用sbt命令,程序会去下载所需要的jar包。整个过程需要很长时间,要耐心等待。当窗口中出现">"提示符,则说明sbt已经成功启动。下载完成后,显示如下图:

sbt命令

帮助命令 help

查看命令的详细帮助文档

显示项目配置 show

show name :查看当前项目的名字。

show libraryDependencies :查看当前项目依赖的库。

使用Scala控制台 console

输入console回车,会在当前会话内启动一个REPL。sbt会加载当前项目依赖的全部jar包和当前的代码。即可以在这个解释器里实验你的半成品。

因为依赖的jar包也都被加载了,所以对于那些你可能还不熟悉的第三方库,你有可以在console里玩个痛快!

运行Scala程序 run

若项目有个对象带有方法(或者对象继承了 App 品质(trait)),那么可以通过输入 run 在 sbt 中运行代码。

在 sbt 发现有多个 main 方法时,它会询问你想执行哪一个。

使用SBT构建项目

在项目目录下创建project目录。

hello-sbt是项目目录。project是其子目录。

在project目录中创建build.properties文件。在文件中写入使用sbt的版本。若本机没有相应的版本,sbt会自动下载需要的版本。(本机使用当前最新sbt版本0.13.9)

在项目目录下,创建build.sbt,填入相应的项目配置

接着在命令行中,进入当前工程,使用sbt命令,当看见尖括号提示符,即表示创建成功。(注:第一次使用sbt需要等待很长时间去下载相应文件。)

将sbt项目导入到Eclipse

在eclipse中使用sbt相应的配置文件,需要安装sbteclipse插件,sbteclipse插件会依据sbt的配置生成eclipse项目需要的文件。

sbteclipse官方地址是 https://github.com/typesafehub/sbteclipse 其中有安装说明。

在工程目录的project目录下创建plugins.sbt,其中添加插件内容。

执行reload命令

接着直接执行eclipse命令,即可生成eclipse项目文件。

在eclipse中导入工程即可:

如果没有创建src目录,手动创建如下目录,然后在重新运行eclipse命令即可。

src/main/scala

src/main/java

src/main/resources

src/test/scala

src/test/scala

src/test/resources

项目导入到Eclipse中显示如下:

若发现src目录下没有resources可以尝试手动创建,也可以在build.sbt中添加如下配置。

EclipseKeys.createSrc := EclipseCreateSrc.Default + EclipseCreateSrc.Resource

总之很简单。

SBT与Scala程序

编写HelloSBT程序。

在src/main/scala中写入HelloSBT程序,生成的eclipse项目如下:

使用sbt编译程序

在sbt命令行下输入compile

使用sbt运行程序

在sbt命令行下输入run

将sbt项目导入到Inetllj IDEA

工程导入Inetllj IDEA,需要选择build.sbt文件,而不是项目文件。Inetllj IDEA会显示对话框。

注意有一些高级选项,可以设置一下。

SBT官网有中文版的文档:http://www.scala-sbt.org/0.13/tutorial/zh-cn/index.html

--------------------------------------更多内容待写--------------------------------------------

时间: 2024-08-27 17:05:36

使用SBT构建Scala项目的相关文章

sbt 构建scala 项目

环境:CentOS 6.3, Scala 2.10.3, Eclipse 1. Scala 安装 如果还没有安装Scala, 请打开以下链接,找到scala安装部分进行安装. http://blog.csdn.net/zlcd1988/article/details/21177187 2. sbt 安装 $ cp -r sbt /usr/lib/ $ tar -xvf sbt-0.13.5.tgz $ export SBT_HOME=/usr/lib/sbt $ export PATH=$PAT

sbt介绍与构建Scala项目

一.sbt简介 sbt是类似ANT.MAVEN的构建工具,全称为Simple build tool,是Scala事实上的标准构建工具. 主要特性: 原生支持编译Scala代码和与诸多Scala测试框架进行交互: 使用Scala编写的DSL(领域特定语言)构建描述 使用Ivy作为库管理工具 持续编译.测试和部署 整合scala解释器快速迭代和调试 支持Java与Scala混合的项目 二.sbt安装 在sbt官网下载,这里我是下载的sbt-0.13.11.zip,下载后加压到自己定义的文件夹,然后将

使用SBT构建Scala应用【转载】

使用SBT构建Scala应用 SBT简介 SBT是Simple Build Tool的简称,如果读者使用过Maven,那么可以简单将SBT看做是Scala世界的Maven,虽然二者各有优劣,但完成的工作基本是类似的. 虽然Maven同样可以管理Scala项目的依赖并进行构建, 但SBT的某些特性却让人如此着迷,比如: 使用Scala作为DSL来定义build文件(one language rules them all); 通过触发执行(trigger execution)特性支持持续的编译与测试

Chisel3-Intellij IDEA中使用sbt构建Chisel项目

https://mp.weixin.qq.com/s/gssjiiPW6zUzKwCFZdNduw 1. 使用Intellij IDEA创建Scala项目 Chisel项目,就是构建Scala项目.Intellij IDEA支持使用Maven等多种方式构建Scala项目: ?? ?? 这里选择Maven和IDEA,都可以很方便的构建项目.尤其是使用IDEA构建项目,不需要额外的下载,直接编写Scala代码,即可完成编译运行. 很遗憾的是,Chisel3的库对sbt有依赖(比如依赖sbt生成的Bu

SBT 构建scala eclipse开发

scala eclipse sbt 应用程序开发 搭建Eclipse开发Scala应用程序的一般步骤 一.环境准备: 1.Scala : http://www.scala-lang.org/ 2.Scala IDE for Eclipse :scala-ide.org 3.Sbt: http://www.scala-sbt.org/ 4.Sbt Eclipse : https://github.com/typesafehub/sbteclipse   typesafe的一个sbt for ecl

使用maven构建scala项目

eclipse安装scala插件和m2e-scala并不是支持的很好,因此使用maven创建scala工程的时候,IDEA可谓是最好的开发利器. 1. 创建工程之前的准备 2. IDEA界面创建Scala的Maven项目 创建工程之前的准备 IntelliJ IDEA Scala plugin for IDEA Maven IDEA界面创建Scala的Maven项目 1. 创建Maven工程,勾选右侧的Create from archetype选项,然后选中下方的scala-archetype-

在IDEA通过Maven构建Scala项目

首先在本地安装scala 我这里已经在本地安装好了. 打开本地的IDEA 安装scala 创建新的项目 选择scala的骨架 在这里提醒一下,本地安装的maven记得添加阿里源,不然很多包就下载不了 <mirror> <id>alimaven</id> <name>aliyun maven</name> <url>http://maven.aliyun.com/nexus/content/groups/public/</url&

SBT 构建 spark streaming集成kafka (scala版本)

前言: 最近在研究spark 还有 kafka , 想通过kafka端获取的数据,利用spark streaming进行一些计算,但搭建整个环境着实不易,故特此写下该过程,分享给大家,希望大家可以少走点弯路,能帮到大家! 环境准备:    操作系统 : ubuntu14.04 LTS hadoop 2.7.1   伪分布式搭建 sbt-0.13.9 kafka_2.11-0.8.2.2 spark-1.3.1-bin-hadoop2.6 scala 版本 : 2.10.4 注: 请重视版本问题,

Eclipse中构建scala开发环境的步骤

Eclipse是一款非常使用的开发工具,熟悉它的童鞋应该都知道,它不仅是最常用的android开发工具,还是最常用的Java开发工具.既然eclipse如此重要,本文小编就和大家一起来扒一扒在eclipse中构建scala开发环境的相关知识,有兴趣的童鞋可以一起来看看. 1.scala是什么 其实,scala是 一种语法,类似Java,而sbt是 一个构建工具,类似maven,gradle,ant等.在eclipse中只有scala开发环境的插件,可以构建scala project,但是没有sb