Scala Language
Kombinatory parsera
Szukaj…
Uwagi
Przypadki ParseResult
ParseResult
występuje w trzech wariantach:
- Sukces, z markerem na początku meczu i kolejną postacią do dopasowania.
- Niepowodzenie, ze znacznikiem początku próby rozpoczęcia meczu. W tym przypadku parser cofa się do tej pozycji, gdzie będzie, gdy parsowanie będzie kontynuowane.
- Błąd, który zatrzymuje przetwarzanie. Nie występuje cofanie ani dalsze przetwarzanie.
Podstawowy przykład
import scala.util.parsing.combinator._
class SimpleParser extends RegexParsers {
// Define a grammar rule, turn it into a regex, and apply it the input.
def word: Parser[String] = """[A-Z][a-z]+""".r ^^ { _.toString }
}
object SimpleParser extends SimpleParser {
val parseAlice = parse(word, "Alice went to Alamo Square.")
val parseBarb = parse(word, "barb went Upside Down.")
}
//Successfully finds a match
println(SimpleParser.parseAlice)
//Fails to find a match
println(SimpleParser.parseBarb)
Dane wyjściowe będą następujące:
[1.6] parsed: Alice
res0: Unit = ()
[1.1] failure: string matching regex `[A-Z][a-z]+' expected but `b' found
barb went Upside Down.
^
[1.6]
w przykładzie Alice
wskazuje, że początek meczu jest na pozycji 1
, a postać, która pozostała do dopasowania, zaczyna się na pozycji 6
.
Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow