Scala Regex示例不起作用

时间:2015-08-04 20:03:09

标签: regex scala

我对scala很陌生,我尝试使用正则表达式解决问题,但我收到了错误。

我直接从文档(2.10.4)复制了一个示例,我得到了同样的错误。

我在这里缺少什么:

println(scala.tools.nsc.Properties.versionString)
val p1 = "ab*c".r
val p2 = "a(b*)c".r

val p1Matches = "abbbc" match {
  case p1() => true
  case _    => false
}

产生

version 2.10.4
Exception in thread "main" java.lang.NoSuchMethodError:  scala.util.matching.Regex.unapplySeq(Ljava/lang/CharSequence;)Lscala/Option;
 at SparkGrep$.argsParser(SparkGrep.scala:67)
 at SparkGrep$.main(SparkGrep.scala:23)
 at SparkGrep.main(SparkGrep.scala)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
...

第67行是说:

  case p1() => true

作为参考,此示例直接从http://www.scala-lang.org/api/2.10.4/index.html#scala.util.matching.Regex

的unappplyseq示例中复制

更新,我已经创建了一个示例项目,其中确实有效。我已经发现它与我的构建过程有关,但我不知道为什么。

这里是破坏项目的build.sbt

name := "logdata-demo-07-22-2015"

version := "1.0"

scalaVersion := "2.10.4"

resolvers ++= Seq(
  "Typesafe Releases" at "http://repo.typesafe.com/ typesafe/releases",
  "spray repo" at "http://repo.spray.io"
)

resolvers += "spray" at "http://repo.spray.io/"

val sparkVersion = "1.3.0"

libraryDependencies ++= Seq(
  "org.apache.spark" %% "spark-mllib" % sparkVersion,
  "org.apache.spark" %% "spark-sql" % sparkVersion,
  "com.databricks" %% "spark-csv" % "1.1.0",
  "com.github.scopt" %% "scopt" % "3.3.0"
)

assemblyMergeStrategy in assembly := {
  case m if m.toLowerCase.endsWith("manifest.mf")          => MergeStrategy.discard
  case m if m.toLowerCase.matches("meta-inf.*\\.sf$")      => MergeStrategy.discard
  case "log4j.properties"                                  => MergeStrategy.discard
  case m if m.toLowerCase.startsWith("meta-inf/services/") => MergeStrategy.filterDistinctLines
  case "reference.conf"                                    => MergeStrategy.concat
  case _                                                   => MergeStrategy.first
}

assemblyOutputPath in assembly := new File("output/logdata-demo.jar")

3 个答案:

答案 0 :(得分:0)

我在Scala上尝试过2.11.6一切正常。 可以连接到Scala版本。

最佳操作是更新为2.11.x。如果您遇到2.10,可以尝试2.10.5

scala> :paste
// Entering paste mode (ctrl-D to finish)

println(scala.tools.nsc.Properties.versionString)
val p1 = "ab*c".r
val p2 = "a(b*)c".r

val p1Matches = "abbbc" match {
  case p1() => true
  case _    => false
}

// Exiting paste mode, now interpreting.

version 2.11.6
p1: scala.util.matching.Regex = ab*c
p2: scala.util.matching.Regex = a(b*)c
p1Matches: Boolean = true

答案 1 :(得分:0)

我在Scala 2.10.4中尝试了这段代码,但效果很好。

您应该尝试以下列方式获取Scala版本,以确保您使用2.10.4

scala.util.Properties.scalaPropOrElse("version.number", "unknown")
  val p1 = "ab*c".r
  val p2 = "a(b*)c".r
  val p1Matches = "abbbc" match {
    case p1() => true
    case _    => false
  }

答案 2 :(得分:0)

这是由于类文件放置不当造成的。它们在构建时位于scala 2.11文件夹中。将它们移动到scala-2.10文件夹修复了问题。

SBT很奇怪