Sie können regex und Pattern-Matching verwenden:
scala> val R = "consumer_key=(.*), consumer_secret=(.*)".r
R: scala.util.matching.Regex = consumer_key=(.*), consumer_secret=(.*)
scala> "consumer_key=1234ABC, consumer_secret=12345ABC" match {
| case R(k, v) => Auth(k, v)
| }
res0: Auth = Auth(1234ABC,12345ABC)
Verwenden flexiblere Analyse:
import scala.util.parsing.combinator._
case class Auth(consumerKey: String, consumerSecret: Option[String])
class AuthParser extends JavaTokenParsers {
def auth: Parser[Auth] = key ~ opt("," ~> secret) ^^ { case k ~ s => Auth(k, s)}
def key: Parser[String] = value("consumer_key")
def secret: Parser[String] = value("consumer_secret")
def value(k: String): Parser[String] = k ~ "=" ~> "[^,]*".r
def apply(s: String) = parseAll(auth, s)
}
Verbrauch:
scala> val p = new AuthParser
p: AuthParser = [email protected]
scala> p("consumer_key=1234ABC, consumer_secret=12345ABC").get
res0: Auth = Auth(1234ABC,Some(12345ABC))
scala> p("consumer_key=1234ABC").get
res1: Auth = Auth(1234ABC,None)
haben alle Ihre Saiten diese Struktur? Wenn ja, warum brechen Sie es nicht explizit? 'val (key, secret) = (s.slice (" consumer_key = ". length, s.indexOf (", ")), s.drop (s.lastIndexOf (" = ")))' –
Nein, ich habe gerade gepostet die ersten beiden aber es gibt mehr. –