我对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")
答案 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很奇怪