Scala RegexParsers

时间:2012-01-13 19:34:46

标签: scala

我使用以下对象来解析csv。解析器似乎正在正常工作,除了空格被剥离。有人可以帮我弄清楚发生了什么。感谢

object CsvParser extends RegexParsers {
  override protected val whiteSpace = """[ \t]""".r

  def COMMA = ","
  def DQUOTE = "\""
  def DQUOTE2 = "\"\"" ^^ { case _ => "\"" }
  def CR = "\r"
  def LF = "\n"
  def CRLF = "\r\n"
  def TXT = "[^\",\r\n]".r

  def record: Parser[List[String]] = rep1sep(field, COMMA)
  def field: Parser[String] = (escaped | nonescaped)
  def escaped: Parser[String] = (DQUOTE ~> ((TXT | COMMA | CR | LF | DQUOTE2)*) <~ DQUOTE) ^^ { case ls => ls.mkString("") }
  def nonescaped: Parser[String] = (TXT*) ^^ { case ls => ls.mkString("") }

  def parse(s: String) = parseAll(record, s) match {
    case Success(res, _) => res
    case _ => List[List[String]]()
  }
}

1 个答案:

答案 0 :(得分:5)

我想我明白了。需要补充:

override val skipWhitespace = false