2
object Test {
   def main(args: Array[String]) {
       val text = "str1"
       text match {
           case "str" => println("str")

           // how to match result return by 'test' methed?
           case test("str", 1) => println("str1")
        }
    }
    def test(str: String, i: Int): String = str + i
}

如何匹配test()方法返回的结果?

测试方法返回一个String-str1

我应该定义一个案例类吗?

4

2 回答 2

4

案例中使用的值不能是函数调用。你可以通过几种方式实现你想要的。在匹配代码之前定义一个等于方法调用结果的 val,并在 case 语句中使用该 val(请注意,val 名称需要以大写字母开头,因为这是告诉编译器使用的特殊语法val,而不是简单地将名称分配给被测值),如下所示:

val text = "str2"
val Check = test("str", 1)
text match {
    case "str" => println("str")

    // how to match result return by 'test' methed?
    case Check => println("str1")
}

或者在case语句中使用过滤器,如下:

case str if (str == test("str", 1)) => println("str1")
于 2013-08-19T04:51:23.740 回答
1

要定义自定义匹配,您需要定义一个提取器(带有unapply方法的对象)。实现它需要解析字符串。这是一些使用解析器组合器执行此操作的代码:

case class StringAndNumber(string: String, number: Int)

object Test {
  def unapply(s: String): Option[StringAndNumber] = Parser(s)
}

object Parser extends scala.util.parsing.combinator.RegexParsers {

  def apply(s: String): Option[StringAndNumber] =
    parseAll(stringAndNumber, s) match {
      case Success(x, _) => Some(x)
      case _ => None
    }

  lazy val stringAndNumber = string ~ number ^^
    { x => StringAndNumber(x._1, x._2) }

  lazy val string = "[^0-9]*".r

  lazy val number = "[0-9]+".r ^^ { _.toInt }
}

def foo(s: String): String = s match {
  case "str" => "str"
  case Test(san) => s"${san.string}|${san.number}"
  case _ => "?"
}

// prints: "str, str|2, ?"
println ( Seq("str", "str2", "2str").map(foo(_)).mkString(", ") )
于 2013-08-19T05:48:32.110 回答