,换个环境,sbt 经常会出现编译项目出错的情况,导入 IDEA 又各种报错,尤其是在 github 上找到一个 sbt 编译的项目,想 clone 下来导入 IDEA 中阅读源码,跑跑测试用例,debug...首先要明白 sbt 其实是一个 Scala 或者 Java 的一个构建工具,使用上的目的和方式其实跟 Maven 是大相径庭的,如果你是 Maven 的老司机,要解决 sbt 的问题,应该不难。...2.1 sbt 本地问题 其实只要 sbt 在本地可以对项目进行构建,就应该不存在 IDEA 构建不了的问题。所以正常的下载安装 sbt 的流程应该是这样的。...2.2 IDEA sbt 的配置问题 如果在本地都能构建项目成功,那么在 IDEA 中也应该成功,因为 IDEA 是支持 sbt 项目的。但这里会有一些坑需要注意一下的。...2.3 一些测试 为了测试 sbt 的配置是否正确了,建议利用 IDEA 创建和导入一个 sbt 项目,尤其是导入一个开源的 sbt 项目,因为这些项目相对比较复杂,sbt 的配置文件中包含了大量的插件和
创建 scala project 选择 create new project: ? 选择 scala - sbt: ? 为项目命名,确认 JDK 为配置的版本: ? ---- 4....创建 scala worksheet 在项目下,如图所示创建 scala worksheet: ? 可以输入 hello world : ? ---- 5....创建 scala class 新建 scala class 的方法: ? 命名: ?...打开 SBT project 的方法 在 Intelli J 的导航 file 处先关闭当前项目: ? 选择 import: ? 选择 build.sbt: ? ? ? ---- 7....同步 SBT and IntelliJ IDEA projects IntelliJ IDEA SBT 支持项目同步,当 scala 版本更新或者增加 library 时,项目可以自动更新。
背景简介 Spark App(用Spark APIs编写的)需要submit到Spark Cluster运行,对于Scala编写的代码,提交之前要用sbt或者maven把以下内容: 源代码 依赖的jar...问题 我司用Scala编写Spark streaming应用,实现读取Kafka数据,处理后存储到cassandra集群中。...总结 对于Java/Scala的编译问题,我曾经特别抗拒,因为maven和sbt的配置文件很冗杂,没有Python的简洁明了。...Python里20行的依赖文件在maven/sbt里至少200行,而且只要有一个地方没写正确就无法正确编译。 现在发现要想正确编译,保证源代码没问题的情况下,就需要指定正确的依赖包和格式。...当看到sbt编译失败的时候就应该根据报错信息推测出问题的原因:“依赖包版本不正确”,然后把版本指定正确就可以了。
SBT 一直以来都是 Scala 开发者不可言说的痛,最主要的原因就是官方文档维护质量较差,没有经过系统的、循序渐进式的整理,导致初学者入门门槛较高。...当然还有另外一个原因可能导致其它构建工具永远没有机会,Scala 语言以其卓越的编译器著称,编译器支持的丰富特性需要和构建工具进行无缝对接,例如 Scala 的 Macro 需要和构建工具的增量编译密切配合...,在和编译器对接方面,SBT 具有先天优势。...下面分享在SBT使用过程中的一些常用技巧。 设置 JVM 参数 有时候我们发现 SBT 编译速度异常缓慢,甚至直接报 OutOfMemory,这时我们就需要调整 JVM 堆大小。...在 SBT 中,有三种方式可以设置 JVM 参数,下面分别介绍。
有些同学可能第一次做对接,由于蛋白或者的受体不同,中途可能会产生一些错误,导致后面无法进行,一直停留在原地,这里,我简单介绍一下,可能的出现的错误,但不一定覆盖到你所遇到的问题。...但是对于蛋白受体来说,一般不会出错的,要出错的情况最可能的原因就是你蛋白受体含有特殊原子,而这些离子在AutoDockTools的离子参数配置文件中没有,所以会报错,这种怎么解决??...还有就是Google,你可以在https://www.researchgate.net/搜索你可能遇到的问题。类似的问题有很多人会遇到的。下面就有一些类似的问题。...在上面的这个问题中,有一个回答, ? 将需要的参数复制到AD4_parameter.dat文件中。...如果对接是你科研的主要内容,那么你需要掌握的不止这些。 ?
一、前述 Scala中的函数还是比较重要的,所以本文章把Scala中可能用到的函数列举如下,并做详细说明。 二、具体函数 1、Scala函数的定义 ?...,要指定传入参数的类型 方法可以写返回值的类型也可以不写,会自动推断,有时候不能省略,必须写,比如在递归函数中或者函数的返回值是函数类型的时候。 ...scala中函数有返回值时,可以写return,也可以不写return,会把函数中最后一行当做结果返回。当写return时,必须要写函数的返回值。...如果返回值可以一行搞定,可以将{}省略不写 传递给方法的参数可以在方法中使用,并且scala规定方法的传过来的参数为val的,不是var的。...** * 包含默认参数值的函数 * 注意: * 1.默认值的函数中,如果传入的参数个数与函数定义相同,则传入的数值会覆盖默认值 * 2.如果不想覆盖默认值,传入的参数个数小于定义的函数的参数
测试 在左侧的项目窗格中,右键单击 src并选择New => Scala Worksheet 点击运行 成功!...2、使用IDEA SBT开发Scala 上面我们通过Idea安装并运行了Scala的程序 我们已经可以在IDEA中开发Scala了!...我们平时的练习与测试完全可以进行了 但是在构建工程时,需要对包版本进行管理,我们最好在IDEA中构建一个标准的Sbt项目 创建 请打开IntelliJ并选择“ Create New Project”...: org.scala-sbt#sbt;0.13.8: not found 1.出现场景:在idea中使用sbt构建工程时,使用默认的sbt版本为0.13.8,而我本地安装的sbt版本是0.13.7,所以在仓库中找不到对应的...0.13.8包 2.解决:在project中的build.properties中把版本号改成本地安装的版本即可,然后在idea工具栏/Build/make project重新重构一下项目 开发代码 在左侧的
sbt类似与maven, gradle的项目管理工具,主要用在scala,也可以用在java项目,本文介绍一下常用的使用命令和语法 安装 mac brew install sbt redhat¢os...session save 保存当前会话信息到build.sbt test执行测试, ~testQuick自动检测并执行测试 projects列出所有项目 build.sbt语法 # 设置scala...")) # 如果配置了子项目,则聚合起来;父项目上执行的命令,也会广播到子项目 .aggregate(helloCore) # 设置对子项目的依赖 .dependsOn(helloCore...,这里的configuration类似于maven中的scope,可以Test, Compile # 如果是scala的库,一般使用%%,这样就会找到对应scala版本的库 libraryDependencies...有时候启动sbt后terminal窗口会停在Getting org.scala-sbt sbt上,也不知道发生了什么。
常量 类型 数组 列表 元组 对象及样例类 四、声明变量中的模式匹配 五、for表达式模式匹配 六、偏函数模式匹配 ---- 本次主要分享Scala中关于模式匹配的内容,Scala中的模式匹配类似于Java...中的switch语法,但是Scala在基于Java的思想上补充了特有的功能。...二、模式守卫 需要进行匹配某个范围的数据内容的时候,可以在模式匹配中进行模式守卫的操作,类似于for推倒式中的循环守卫。...,unapply 方法将 student 对象的 name 和 age 属性提取出来,与 Student("alice", 15)) 中的属性值进行匹配 case 中对象的 unapply 方法(提取器...中的模式匹配部分到这里就结束了,知识点较为简单但是使用起来特别的灵活,希望对大家有所帮助!!!
本文的主要内容是帮助初学者从头到尾构建并运行一个Scala项目,重点在于讲解国内镜像仓库的配置。...在 SBT 中,有三种方法可以设置 Java System Property,可以根据需要自行选择。...=true -Dsbt.repository.config=path_to_repositories_file 第三步:构建并运行第一个Scala项目 1)修改项目SBT构建版本 单击 hello-scala...下载一个最简单的Scala项目,并解压到指定目录,如 D:\idea-projects 。...检查当前项目的SBT构建版本是否为1.3.0, sbt:hello-scala> sbtVersion [info] 1.3.0 sbt:hello-scala> 2)确认全局仓库是否已经覆盖项目自身仓库
发布Play项目 Play项目的发布也是通过sbt命令完成的,进入命令行执行sbt dist,命令执行完成后,在target\universal目录下会生成应用文件play-scala-starter-example...bin目录中包含了应用的启动脚本play-scala-starter-example,与项目名称同名。...IDEA将会先进行项目构建,构建成功后显示项目主窗口: ? 如果修改了Play项目的某些配置,但是在IDEA中没有立即生效,单击右侧SBT projects窗口左上角的蓝色刷新按钮 即可。...通常的开发流程是:首先在命令行执行sbt run,以开发模式启动项目,在浏览器中打开http://localhost:9000 ,然后在IDEA中修改代码,改完后直接刷新浏览器即可。...这是由于模板函数index是在项目编译过程中动态生成的,所以新增的模板函数在IDEA中会提示找不到,这时只要在命令行执行sbt compile,然后在SBT projects窗口单击蓝色刷新按钮,错误即会消失
Scala中的immutable Collection 集合 Traversable 遍历 Iterable 迭代 Set无序集合 Sequence序列 Map映射 Set...,表明一个转换过程,参数中的匿名函数参数x是List中得每个元素 //使用map实现全部字母大写 scala> c.map(x => x.toUpperCase) res23: List[String]...filter和map来实现对List中过滤后元素的具体操作 //下面是将奇数全部加10 scala> a.filter( _ % 2 ==1).map( _ + 10) res26: List[Int...scala> s.tail.head res50: Int = 2 Scala中的tuple:元组 //元组的概念,和Python中的元组类似,可以放不用类型的变量 scala> (1,2) res51...> _3operate(a) res56: (Int, Int, Int) = (4,10,30) Scala中的Map //使用类似元组的箭头来定义一个键值对 scala> val p = Map(1
Java中异常处理有两种方式 try...catch和finally概述 finally重要面试题 三、Scala中的异常机制 ---- Scala中的异常机制语法处理上和 Java 类似,但是又不尽相同...中的异常机制 将会发生异常的代码封装在 try 块中。...Scala 的异常的工作机制和 Java 一样,但是 Scala 没有“checked(编译期)”异常,即 Scala没有编译异常这个概念,异常都是在运行的时候捕获处理。...因此,在 catch 子句中,越具体的异常越要靠前,越普遍的异常越靠后,如果把越普遍的异常写在前,把具体的异常写在后,在 Scala 中也不会报错,但这样是非常不好的编程风格。...它向调用者函数提供了此方法可能引发此异常的信息。它有助于调用函数处理并将该代码包含在 try-catch块中,以避免程序异常终止。在 Scala 中,可以使用 throws 注解来声明异常。
注:先前的文章里记得有个地方对这个问题表述的不正确,有时间再改。...原错误信息 原错误出现的IDEA版本:2017.2; 原错误的出现场景:每次新建SBT项目并添加完SBT依赖之后出现; 原错误的表现:build.sbt文件内容解析全部是红的,并且sbt shell报错...from C:/Users/msi/.IntelliJIdea2017.2/config/plugins/Scala/launcher/sbt-structure-1.1.jar [error] java.lang.ClassNotFoundException...[error] at xsbt.boot.Boot$.main(Boot.scala:17) [error] at xsbt.boot.Boot.main(Boot.scala) [error] java.lang.ClassNotFoundException...参考 IDEA官方社区的帖子 ?
2 导入 Delta Lake 到 IDEA Delta Lake 是用 sbt 构建的项目,所以想要自行打包构建,大家还是需要熟悉一下 sbt 的。...不熟悉 sbt 的同学很容易从入门到放弃,IDEA 的 sbt 就更甚了,经常有各种各样的问题,而恰恰 Delta 又是一个使用 sbt 做依赖管理的项目,所以想要用 IDEA 愉快的研究 Delta...其实之所以很多同学都导入不成功,是因为不太熟悉 sbt,包括本屌也是,其实算不上熟悉,最多叫做会用一点点。由于大家本地环境千差万别,我这里只说说我本地环境导入项目时候遇到的一些问题。...之后我们就可以在 IDEA 中运行各种测试用例,打断点 debug 等学习了。 ?...3 Summary 不熟悉 sbt 的同学很可能会因为导入 IDEA 的时候出现问题而放弃研究这个项目(我以前可能就是这样…),毕竟导入之后,我们才可以愉快的进行各种调试。
通过Scala对文件进行读写操作在实际业务中应用也比较多,这里介绍几种常用的方式,直接上代码: 1.从文件中读取内容 object Main { def loadData(): Array[String...write(): Unit ={ //调用的就是java中的io类 val writer = new PrintWriter(new File("write.txt" )) writer.write...("scala write") writer.close()} 除了上述读写方式,也可以从"屏幕"上读取用户输入的指令来处理程序: import scala.io....所以,在并发环境下,要注意调用该方法时的线程安全问题,比如利用synchronized做锁处理。...这里只是以ArrayBuffer为例,对于Scala中其他的集合使用时也要注意,防止类似问题的出现影响程序的正常运行。
通过Scala对文件进行读写操作在实际业务中应用也比较多,这里介绍几种常用的方式,直接上代码: 1.从文件中读取内容 object Main { def loadData(): Array[...def write(): Unit ={ //调用的就是java中的io类 val writer = new PrintWriter(new File("write.txt" ))...writer.write("scala write") writer.close() } 除了上述读写方式,也可以从"屏幕"上读取用户输入的指令来处理程序: import scala.io....所以,在并发环境下,要注意调用该方法时的线程安全问题,比如利用synchronized做锁处理。...这里只是以ArrayBuffer为例,对于Scala中其他的集合使用时也要注意,防止类似问题的出现影响程序的正常运行。
二、SBT简介 使用Scala语言编程,最好使用SBT框架,可以自动帮你完成包管理等,相当于java中的maven,下面先简单介绍一下SBT基础。 ...安装完成之后,在IDEA中安装sbt插件,然后选择创建SBT项目,与普通Scala语言最主要的不同是会创建一个build.sbt文件,这个文件主要记录的就是项目的依赖等,要添加依赖就可以添加如下两行代码...引入akka只需要在build.sbt文件中添加在SBT操作一节中介绍的代码即可,但是要根据自己的Scala版本以及要使用的akka版本进行修改。添加完之后IDEA会自动去下载akka的actor包。...首先建立一个RemoteActor项目,将build.sbt中项目的引用改为libraryDependencies ++= Seq("com.typesafe.akka" % "akka-actor_2.11...然后新建一个LocalActor项目,同样修改build.sbt文件中的内容如上,然后新建一个LocalActor类,由于此处需要向RemoteActor发送消息,所以必须建立一个RemoteActor
Spark在2013年6月进入Apache成为孵化项目,8个月后成为Apache顶级项目,速度之快足见过人之处,Spark以其先进的设计理念,迅速成为社区的热门项目,围绕着Spark推出了Spark SQL...从各方面报道来看Spark抱负并非池鱼,而是希望替代Hadoop在大数据中的地位,成为大数据处理的主流标准,不过Spark还没有太多大项目的检验,离这个目标还有很大路要走。...在大版本2.10.x范围内一致,否则在某些情况下可能会出现莫名其妙的问题。...sbt,专门针对scala项目的进行构建打包的 好吧,也许你需要一个demo来帮助你理解?...在IDEA中,创建一个Scala的SBT项目: 然后在build.sbt文件中,加入如下依赖: Java代码 name := "spark2117" version := "1.0"
开始学习spark ml了,都知道spark是继hadoop后的大数据利器,很多人都在使用spark的分布式并行来处理大数据。spark中也提供了机器学习的包,就是MLlib。...MLlib中也包含了大部分常用的算法,分类、回归、聚类等等,借助于spark的分布式特性,机器学习在spark将能提高很多的速度。MLlib底层采用数值计算库Breeze和基础线性代数库BLAS。...具体scala和idea怎么配,网上多的是教程。 配好后,我们来新建一个project,然后选择sbt。 ? ? 在scala这里选择一个scala版本。 然后创建完毕这个sbt项目。...注意,你会经历比较漫长的等待,等待sbt的各种jar包下载完毕,然后你的项目才能创建成功。 sbt你可以理解为一种构建方式,和maven、gradle一样,通过sbt能管理你需要依赖的jar。...创建后的项目长这样,build.sbt里面就是配置项目的基本属性的,用过gradle的应该比较熟悉这种写法。
领取专属 10元无门槛券
手把手带您无忧上云