IDEA创建Maven的Scala项目详解

3 篇文章 0 订阅
2 篇文章 0 订阅
一、Windows安装Scala

官网下载:Scala

  1. 解压。例如解压到D:\Software\scala-2.13.2
  2. 新建系统变量SCALA_HOME,为D:\Software\scala-2.13.2,添加入PATH
    在这里插入图片描述
    在这里插入图片描述
  3. cmd打开控制台,查看是否安装成功
    在这里插入图片描述
二、IDEA配置scala-sdk

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

三、创建项目

在这里插入图片描述
在这里插入图片描述

四、问题
  1. Failed to execute goal org.scala-tools:maven-scala-plugin:2.15.2:compile(default) on Project DataFus
    原因:IDEA的Scala版本与Windows里的Scala版本不兼容。IDEA默认设置的Scala版本为2.7.0,必须修改
    解决:
  • Windows的scala-sdk版本必须大于IDEA设置的scala版本,可Windows安装高版本的Scala或者IDEA设置低版本的Scala
  • 示例是Windows的Scala版本为2.13.2(即scala-sdk-2.13.2),IDEA设置Scala版本为2.11.12
  		<properties>
    		<scala.version>2.11.12</scala.version>
  		</properties>
  1. Failed to execute goal org.scala-tools:maven-scala-plugin:2.15.2:testCompile (default) on project WordCount: wrap: org.apache.commons.exec.ExecuteException: Process exited with an error: 1(Exit value: 1)
    解决:
  • Scala2.9以后就弃用了Application,所以使用2.11版本要用App替代Application,用Main替代App
  • 删除test/scala目录下的MySpec文件
		object Main extends App {
  			println( "Hello World!" )
		}

在这里插入图片描述
3. build.plugins.plugin.version’ for org.scala-tools:maven-scala-plugin is missing. @ line 51, column 15
‘build.plugins.plugin.version’ for org.apache.maven.plugins:maven-eclipse-plugin is missing. @ line 69, column 15
解决:

  • 添加依赖
    <dependency>
     <groupId>org.scala-tools</groupId>
     <artifactId>maven-scala-plugin</artifactId>
     <version>2.11</version>
   </dependency>
   <dependency>
     <groupId>org.apache.maven.plugins</groupId>
     <artifactId>maven-eclipse-plugin</artifactId>
     <version>2.5.1</version>
   </dependency>
  • 设置maven-scala-plugin和maven-eclipse-plugin的版本
        <groupId>org.scala-tools</groupId>
        <artifactId>maven-scala-plugin</artifactId>
        <version>2.11</version>
        
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-eclipse-plugin</artifactId>
        <version>2.5.1</version>
  1. Using platform encoding (UTF-8 actually) to copy filtered resources, i.e. build is platform dependent!
    解决:**
  • 设置UTF-8编码
		<properties>
			<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
			<scala.version>2.11.12</scala.version>
		</properties>

完整的POM文件

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>org.bing</groupId>
  <artifactId>WordCount</artifactId>
  <version>1.0-SNAPSHOT</version>
  <inceptionYear>2008</inceptionYear>
  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <scala.version>2.11.12</scala.version>
  </properties>

  <repositories>
    <repository>
      <id>scala-tools.org</id>
      <name>Scala-Tools Maven2 Repository</name>
      <url>http://scala-tools.org/repo-releases</url>
    </repository>
  </repositories>

  <pluginRepositories>
    <pluginRepository>
      <id>scala-tools.org</id>
      <name>Scala-Tools Maven2 Repository</name>
      <url>http://scala-tools.org/repo-releases</url>
    </pluginRepository>
  </pluginRepositories>

  <dependencies>
    <dependency>
      <groupId>org.scala-lang</groupId>
      <artifactId>scala-library</artifactId>
      <version>${scala.version}</version>
    </dependency>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.4</version>
      <scope>test</scope>
    </dependency>
    <dependency>
      <groupId>org.specs</groupId>
      <artifactId>specs</artifactId>
      <version>1.2.5</version>
      <scope>test</scope>
    </dependency>
    
    <!--避免下面的插件出错-->
    <dependency>
      <groupId>org.scala-tools</groupId>
      <artifactId>maven-scala-plugin</artifactId>
      <version>2.11</version>
    </dependency>
    <dependency>
      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-eclipse-plugin</artifactId>
      <version>2.5.1</version>
    </dependency>
  </dependencies>

  <build>
    <sourceDirectory>src/main/scala</sourceDirectory>
    <testSourceDirectory>src/test/scala</testSourceDirectory>
    <plugins>
      <plugin>
        <groupId>org.scala-tools</groupId>
        <artifactId>maven-scala-plugin</artifactId>
        <version>2.11</version>
        <executions>
          <execution>
            <goals>
              <goal>compile</goal>
              <goal>testCompile</goal>
            </goals>
          </execution>
        </executions>
        <configuration>
          <scalaVersion>${scala.version}</scalaVersion>
          <args>
            <arg>-target:jvm-1.8</arg>
          </args>
        </configuration>
      </plugin>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-eclipse-plugin</artifactId>
        <version>2.5.1</version>
        <configuration>
          <downloadSources>true</downloadSources>
          <buildcommands>
            <buildcommand>ch.epfl.lamp.sdt.core.scalabuilder</buildcommand>
          </buildcommands>
          <additionalProjectnatures>
            <projectnature>ch.epfl.lamp.sdt.core.scalanature</projectnature>
          </additionalProjectnatures>
          <classpathContainers>
            <classpathContainer>org.eclipse.jdt.launching.JRE_CONTAINER</classpathContainer>
            <classpathContainer>ch.epfl.lamp.sdt.launching.SCALA_CONTAINER</classpathContainer>
          </classpathContainers>
        </configuration>
      </plugin>
    </plugins>
  </build>
  <reporting>
    <plugins>
      <plugin>
        <groupId>org.scala-tools</groupId>
        <artifactId>maven-scala-plugin</artifactId>
        <configuration>
          <scalaVersion>${scala.version}</scalaVersion>
        </configuration>
      </plugin>
    </plugins>
  </reporting>
</project>
  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 使用 IntelliJ IDEA 创建 Scala Maven 项目的步骤如下: 1. 打开 IntelliJ IDEA,选择 “Create New Project”。 2. 选择 “Maven” 模板。 3. 在 “Project SDK” 选项中选择已安装的 JDK 版本。 4. 在 “Project language level” 选项中选择 “Scala”。 5. 在 “Artifact” 选项中填入项目名称。 6. 点击 “Finish” 创建项目项目创建完成后,需要在 pom.xml 文件中添加 scala 依赖,如下 ``` <dependency> <groupId>org.scala-lang</groupId> <artifactId>scala-library</artifactId> <version>2.13.3</version> </dependency> ``` 同时也可以在setting->build->compiler->scala compiler中设置scala的版本 ### 回答2: 要创建一个Scala Maven项目,需要按照以下步骤操作: 1. 安装ScalaMaven 首先需要确保电脑已经安装了ScalaMaven。如果没有安装,可以参考相关文档进行安装。 2. 创建Maven项目 在命令行中运行以下命令: ``` mvn archetype:generate -DgroupId=com.example -DartifactId=myproject -DarchetypeArtifactId=maven-archetype-quickstart -DinteractiveMode=false ``` 这个命令会创建一个Maven项目,并生成一个初始的Java类。 3. 引入Scala依赖 在项目中的pom.xml文件中加入Scala相关的依赖: ```xml <dependencies> <dependency> <groupId>org.scala-lang</groupId> <artifactId>scala-library</artifactId> <version>2.13.0</version> </dependency> <dependency> <groupId>org.scala-lang</groupId> <artifactId>scala-compiler</artifactId> <version>2.13.0</version> <scope>provided</scope> </dependency> </dependencies> ``` 其中,scala-library是Scala标准库,scala-compiler是Scala编译器。 4. 编写Scala代码 在src/main/scala目录下创建Scala源代码文件,并编写相应的代码。 5. 编译打包 在命令行中运行以下命令进行编译打包: ``` mvn package ``` 这个命令会生成一个jar包,可以在target目录下找到。 以上就是创建一个Scala Maven项目的步骤。创建一个Scala Maven项目可以帮助我们更好地管理依赖和打包发布。 ### 回答3: 在创建Scala Maven项目之前,我们需要确保已经安装了Java和Maven,并且已经配置了环境变量。 接下来,我们可以通过以下步骤来创建Scala Maven项目: 1.打开终端或命令行界面,使用`mkdir`命令创建一个名为`scala-maven-project`的文件夹,该文件夹将包含我们的Scala Maven项目。 2.使用`cd`命令进入该文件夹。 3.使用Maven的`archetype:generate`命令来生成Scala项目。可以使用以下命令: ``` mvn org.apache.maven.plugins:maven-archetype-plugin:2.4:generate \ -DgroupId=com.example.scala \ -DartifactId=scala-maven-project \ -DarchetypeArtifactId=maven-archetype-quickstart \ -DinteractiveMode=false \ -DarchetypeVersion=1.4 ``` 其中,`-DgroupId`是项目的包名,`-DartifactId`是项目的名称,`-DarchetypeArtifactId`是要使用的Maven archetype。 4.在项目目录中,找到`src/main/scala`文件夹,用`vim`或其他文本编辑器打开`App.scala`文件。 5.编写Scala代码,例如: ``` object App { def main(args: Array[String]): Unit = { println("Hello, Scala!") } } ``` 6.在项目目录中,执行`mvn compile`命令,以编译Scala代码并生成类文件。 7.执行`mvn package`命令,以将Scala类文件打包为可执行的jar文件。 8.在`target`目录中找到生成的jar文件,例如`scala-maven-project-1.0-SNAPSHOT.jar`。 9.执行`java -jar target/scala-maven-project-1.0-SNAPSHOT.jar`命令,以运行Scala程序。 这样,我们就可以成功创建Scala Maven项目,并用Scala语言编写了一个简单的Hello World程序,并成功打包为可执行的jar文件。 可以通过执行`java -jar`命令来运行该程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值