1

我正在尝试学习 scala 快速解析库。为此,我编写了以下代码

import fastparse.noApi._
import fastparse.WhitespaceApi

object FastParsePOC {

   val White = WhitespaceApi.Wrapper{
      import fastparse.all._
      NoTrace(" ".rep)
   }

   def print(input : Parsed[String]): Unit = {
      input match {
         case Parsed.Success(value, index) => println(s"Success: $value $index")
         case f @ Parsed.Failure(error, line, col) => println(s"Error: $error $line $col ${f.extra.traced.trace}")
      }
   }

   def main(args: Array[String]) : Unit = {
      import White._
      val parser = P("Foo" ~ "(" ~ AnyChar.rep(1).! ~ ")")
      val input1 = "Foo(Bar(10), Baz(20))"
      print(parser.parse(input1))
   }
}

但我得到错误

Error: ")" 21 Extra(Foo(Bar(10), Baz(20)), [traced - not evaluated]) parser:1:1 / (AnyChar | ")"):1:21 ...""

我的预期输出是“Bar(10), Baz(20)”。上面的解析器似乎不喜欢结尾“)”。

4

1 回答 1

4

AnyChar.rep(1)还包括)输入字符串末尾的符号,因此未到达)末尾。~ ")")如果)Bar 和 Baz 中未使用符号,则可以通过以下方式排除来)解决AnyChar

val parser = P("Foo" ~ "(" ~ (!")" ~ AnyChar).rep(1).! ~ ")")
val input1 = "Foo(Bar(10*, Baz(20*)"

要使 Bar 和 Baz 与)符号一起使用,您可以为它们中的每一个定义单独的解析器(也将)符号从AnyChar.

val bar = P("Bar" ~ "(" ~ (!")" ~ AnyChar).rep(1) ~ ")")
val baz = P("Baz" ~ "(" ~ (!")" ~ AnyChar).rep(1) ~ ")")
val parser = P("Foo" ~ "(" ~ (bar | baz).rep(sep = ",").! ~ ")")
val input1 = "Foo(Bar(10), Baz(20))"
print(parser.parse(input1))

结果:
Success: Bar(10), Baz(20) 21

于 2016-08-14T07:48:15.730 回答