正則表達(dá)式是用于找出數(shù)據(jù)中模式的字符串。任何字符串都可以使用.r
方法轉(zhuǎn)換為正則表達(dá)式每窖。
import scala.util.matching.Regex
val numberPattern: Regex = "[0-9]".r
numberPattern.findFirstMatchIn("awesomepassword") match {
case Some(_) => println("Password OK")
case None => println("Password must contain a number")
}
在上面例子中帮掉,numberPattern
是一個Regex
(正則表達(dá)式),用于確認(rèn)密碼中是否包含數(shù)字窒典。
也可以使用括號搜索正則表達(dá)式組蟆炊。
import scala.util.matching.Regex
val keyValPattern: Regex = "([0-9a-zA-Z-#() ]+): ([0-9a-zA-Z-#() ]+)".r
val input: String =
"""background-color: #A03300;
|background-image: url(img/header100.png);
|background-position: top center;
|background-repeat: repeat-x;
|background-size: 2160px 108px;
|margin: 0;
|height: 108px;
|width: 100%;""".stripMargin
for (patternMatch <- keyValPattern.findAllMatchIn(input))
println(s"key: ${patternMatch.group(1)} value: ${patternMatch.group(2)}")
這里我們解析字符串的鍵和值。每個匹配都有一組自匹配瀑志。下面是輸出:
key: background-color value: #A03300
key: background-image value: url(img
key: background-position value: top center
key: background-repeat value: repeat-x
key: background-size value: 2160px 108px
key: margin value: 0
key: height value: 108px
key: width value: 100