如何使用模式匹配在scala中获取一个nonEmpty列表?

Lor*_*hen 10 scala pattern-matching

我正在case x :: Nil => ...尝试确保列表是非空的,但它只匹配单个元素列表.如何使用模式匹配获取非空列表?

更新
我很抱歉,似乎我失去了一些东西,有一个特殊的场景使用匹配内部,

object AccountResult{
  def unapply(account: AccountResult): Option[(String, List[String])] = ???
}

//ignore accountResult define please 
accountResult match {
  case AccountResult(_, x :: _) => ... 
}
Run Code Online (Sandbox Code Playgroud)

如何匹配accountResult哪个List [String](x :: _)值不是Nil?然后获取匹配的List [String]值

Sha*_*nds 19

而不是仅指定空列表Nil,指定可以是任何列表的内容,例如:

case x :: tail => ... // tail is a local variable just like x, holding the tail of the list
Run Code Online (Sandbox Code Playgroud)

或者干脆:

case x :: _ => ...
Run Code Online (Sandbox Code Playgroud)

如果你不关心或不会使用尾巴.

这些模式将匹配具有至少一个元素的任何列表(而不是根据现有模式恰好一个元素).同样,模式:

case x :: y :: the_rest => ...
Run Code Online (Sandbox Code Playgroud)

将匹配任何列表至少包含两个元素.

编辑(回复您的评论):

您可以使用" @" 分配案例模式中的变量.因此,对于您可能已经看过的(典型用法)示例:

case acc@AccountResult(_, x :: tail) => ... // do something with 'acc'
Run Code Online (Sandbox Code Playgroud)

或者,根据您的评论匹配您正在寻找的用法:

case AccountResult(_, phone@(x :: tail)) => ... // do something with 'phone'
Run Code Online (Sandbox Code Playgroud)


Nya*_*vro 16

要检查列表是否为空,您可以通过以下方式匹配模式:

list match {
   case Nil => false
   case _ => true
}
Run Code Online (Sandbox Code Playgroud)

要么

list match {
  case Nil => false
  case x::xs => true  
}
Run Code Online (Sandbox Code Playgroud)

  • 请注意,顺序很重要,否则将无法访问 `case Nil`。 (3认同)

Vis*_*edo 7

如果您只想将整个非空列表分配给一个 val,而不拆分头和尾,您只需添加一个匹配空列表的案例,另一个将列表分配给一个变量名,如下所示:

accountResult match {
  case List() => ??? // empty case
  case myAccountResult => ??? //myAccountResult will contain the whole non-empty list  
}
Run Code Online (Sandbox Code Playgroud)

Nil 也可以完成这项工作,匹配一个空列表

accountResult match {
  case Nil => ??? // empty case
  case myAccountResult => ??? //myAccountResult will contain the whole non-empty list  
}
Run Code Online (Sandbox Code Playgroud)