关于scala工程结构(使用sbt)
scala_project:
常用目录结构:
|lib:手动添加依赖包
|project
| |build.properties:build的版本号,可以不写,会自动下载
| |plugins.sbt:需要添加的插件,包括sbt的插件(addSbtPlugin),否则sbt gen-idea、assembly命令不能执行(Not a valid command: assembly)
| |build.scala:功能类似于build.sbt,声明工程文件,同时通过setting方式设定工程名字、版本、依赖(需要Dependencies文件)等信息
|src
| |main
| |resources:工程的配置文件,sbt工程默认读取该目录下配置文件(ConfigFactory.load(),ConfigFactory.parseFile(),生成config)
| |scala
| |java
| |test
| |resources
| |scala
| |java
|target:生成工程jar包和idea工程的xml
|build.sbt:工程name、version、scalaVersion、libraryDependencies等
注意:build.sbt和build.scala可以取一即可。
一、使用build.sbt搭建工程:
A.build.sbt(每行以空行分割)
import sbtassembly.Plugin.AssemblyKeys._
import sbt.Keys._
name:="config_read"
version:="1.1"
scalaVersion:="2.10.1"
assemblySettings//需要指定,否则sbt assembly命令无效
jarName in assembly:="scalatest_20170818.jar"
mainClass in assembly:=Some("MyTest")
libraryDependencies+="com.typesafe"%"config"%"1.2.1" //依赖的第三方包
libraryDependencies+="org.slf4j"%"slf4j-api"%"1.7.7" //依赖的第三方包
B.plugins.sbt(每行以空行分割)
//需要留空行,以下为sbt构建、编译、打包必须的插件
addSbtPlugin("com.github.mpeltonen" % "sbt-idea" % "1.6.0")
addSbtPlugin("com.eed3si9n" % "sbt-assembly" % "0.11.2")
addSbtPlugin("de.johoop" % "jacoco4sbt" % "2.1.5")
C.build.properties(指定sbt版本)
sbt.version=0.13.7
二、使用build.scala
目录结构(一个工程下多个子工程):
|project
|BuildProject.scala
|Dependencies.scala
|plugins.sbt
|build.properties
|Common.scala
|rdd_proj
|date_goodsstatistic
|src
|mian
|resources
|scala
|java
|date_salaryincharge
|src
|main
|resources
|scala
|java
A.BuikdProject.scala(该文件为scala文件object,依赖于Dependencies)
import sbt.Keys._
import sbt._
import sbtassembly.AssemblyKeys._
object BuildProject extends Build {
lazy val goodsstatistic= project.in(file("rdd_proj/date_goodsstatistic")).settings(name := "date_goodsstatistic").
settings(Common.settings: _*).
settings(libraryDependencies ++= Dependencies.sparkCounterDependencies).
settings(assemblyOption in assembly := (assemblyOption in assembly).value.copy(includeScala = false)).
settings(assemblyJarName in assembly := s"date_goodsstatistic_1.2.1.jar")
lazy val salaryincharge = project.in(file("rdd_proj/date_salaryincharge")).settings(name := "date_salaryincharge").
settings(Common.settings: _*).
settings(libraryDependencies ++= Dependencies.sparkCounterDependencies).
settings(assemblyOption in assembly := (assemblyOption in assembly).value.copy(includeScala = false)).
settings(assemblyJarName in assembly := s"date_salaryincharge_1.3.1.jar")
}
B.Dependencies.scala(该文件为scala文件object)
import sbt._
object Dependencies {
val sparkDependencies: Seq[ModuleID] = Seq(
"org.apache.spark" % "spark-core" % "2.0.0" %“provided,test”,
"org.apache.spark" % "hadoop-common" % "2.11-2.0.2"% "provided,test",//provided指明环境含有该依赖包,本地test时需要下载,打包时不需要
"org.apache.spark" % "spark-hive" % "2.11-2.0.2"% "provided,test")
val featureDependencies:Seq[MoudleID]=Seq(
"org.scalatest" %% "scalatest" % "2.2.4" % "test",
"mysql" % "mysql-connector-java" % "5.1.31" % "test")
val sparkCounterDependencies:Seq[MoudleID]=sparkDependencies++featureDependencies:Seq
}
C.plugins.sbt(同一)
D.build.properties(同一)
E.Common.scala(可以指定scalaVersion)
关于scala工程结构(使用sbt)的更多相关文章
- Scala构建工具SBT
SBT(Simple Build Tool)是Scala的项目构建工具,拥有依赖管理,构建过程管理和打包等功能. SBT官网上给出各平台的安装方法: MAC: 使用homebrew安装 brew in ...
- Scala构建工具sbt的配置
时间是17年12月24日.初学Scala,想使用它的标配构建工具sbt,结果好大一轮折腾,因为公司隔离外网,需要内部代理,所以尤其折腾.下面的配置参考了好多篇不同的文章,已经没法一一留下出处了.而且还 ...
- 使用SBT构建Scala应用(转自git)
# 使用SBT构建Scala应用 ## SBT简介 SBT是Simple Build Tool的简称,如果读者使用过Maven,那么可以简单将SBT看做是Scala世界的Maven,虽然二者各有优劣, ...
- 【原】SBT构建Scala应用
[转帖] 原文地址:https://github.com/CSUG/real_world_scala/blob/master/02_sbt.markdown 尊重版权,尊重他人劳动成果,转帖请注明原文 ...
- 使用SBT构建Scala应用【转载】
使用SBT构建Scala应用 SBT简介 SBT是Simple Build Tool的简称,如果读者使用过Maven,那么可以简单将SBT看做是Scala世界的Maven,虽然二者各有优劣,但完成的工 ...
- Spark开发环境搭建(IDEA、Scala、SVN、SBT)
软件版本 软件信息 软件名称 版本 下载地址 备注 Java 1.8 https://www.oracle.com/technetwork/java/javase/downloads/jdk8-dow ...
- sbt介绍与构建Scala项目
一.sbt简介 sbt是类似ANT.MAVEN的构建工具,全称为Simple build tool,是Scala事实上的标准构建工具. 主要特性: 原生支持编译Scala代码和与诸多Scala测试框架 ...
- ubuntu14.04server下安装scala+sbt工具
安装sbt参考https://www.cnblogs.com/wrencai/p/3867898.html 在安装scala时 首先得安装jdk环境,最好安装最新版本以免后续安装出现不必要的麻烦 一. ...
- Scala 基础(二):sbt介绍与构建Scala项目
一.sbt简介 sbt是类似ANT.MAVEN的构建工具,全称为Simple build tool,是Scala事实上的标准构建工具. 主要特性: 原生支持编译Scala代码和与诸多Scala测试框架 ...
随机推荐
- net.sf.json.JSONObject maven下载到了但是java后台一直用不了问题
需求,实体转JSON,然后用到JSONObject转JSON,但是我向下面这样引入,后台就是用不了,还是报红, <dependency> <groupId>net.sf.jso ...
- 《ES6标准入门》(阮一峰)--7.数值的扩展
1.二进制和八进制表示法 ES6 提供了二进制和八进制数值的新的写法,分别用前缀0b(或0B)和0o(或0O)表示. 0b111110111 === 503 // true 0o767 === 503 ...
- RadioGroup的使用
前言: 使用RadioGroup就可以在选择情况多的时候,简化代码 RadioGroup 使用互斥选择时,会使用RadioGroup标签下面RadioButton,如下面的代码:(这样写下来,男和女的 ...
- Postman配置Pre-request scripts预请求对请求进行AES加密
1.首先,Postman的Pre-request scripts页面右边已经提供了一些模板,这些模板可以设置变量与环境变量,并使用双大括号对变量进行引用 {{info}} 2.对所有POST请求都进行 ...
- cf 763A. Timofey and a tree
呵呵呵,直接判断是不是一个点连起来所有的特殊边(连接2不同颜色的点的边) (一开始还想各种各样奇怪的dfs...垃圾) #include<bits/stdc++.h> #define LL ...
- Swift 元组 Tuple
let infoArray:[Any] = ["jack",18,1.88] let infoName=infoArray[0] as!String //此处为Any类型强转为St ...
- 经验分享:如何搞定Personal Statement?
最近又到申请季啦,如何自己DIY申请,如何准备文书成为众多留学生关心的问题.不管是你申请本科,硕士,还是博士,相信这篇文章都能帮助到你.下面来说一下文书中一个很重要的组成,就是个人陈述Personal ...
- 干货分享|留学Essay怎么写?
留学生活其实就是分割成一个个deadline,留学就是赶完一个又一个deadline.朋友同学的革命情感源自赶一个个deadline时候的不离不弃,相知相守,无数个夜里大家群里打卡,你今天Essay写 ...
- 课程作业02-1-课后作业1-(1)使用组合数公式利用n!来计算
1.设计思想:运用递归阶乘的函数,依次求出n!.k!.(n-k)!,再根据组合数的公式计算(n!/(k!*(n-k)!)). 2.程序流程图: 3.源程序代码: //信1605-3 20163429 ...
- ArryList的使用方法(基础使用-将来会不断添加)
转自:http://www.cnblogs.com/ysz12300/p/5595907.html 引入ArryList的方法->命名空间:using System.Collections; A ...