国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Regex > 正文

Scala中正則表達式以及與模式匹配結(jié)合(多種方式)

2020-03-16 20:43:59
字體:
供稿:網(wǎng)友

正則表達式

 //"""原生表達 val regex="""([0-9]+)([a-z]+)""".r val numPattern="[0-9]+".r val numberPattern="""/s+[0-9]+/s+""".r

說明:.r()方法簡介:Scala中將字符串轉(zhuǎn)換為正則表達式

 /** You can follow a string with `.r`, turning it into a `Regex`. E.g. * * `"""A/w*""".r` is the regular expression for identifiers starting with `A`. */ def r: Regex = r()

模式匹配一

 //findAllIn()方法返回遍歷所有匹配項的迭代器 for(matchString <- numPattern.findAllIn("99345 Scala,22298 Spark"))  println(matchString)

說明:findAllIn(…)函數(shù)簡介

/** Return all non-overlapping matches of this `Regex` in the given character  * sequence as a [[scala.util.matching.Regex.MatchIterator]], * which is a special [[scala.collection.Iterator]] that returns the * matched strings but can also be queried for more data about the last match, * such as capturing groups and start position. *  * A `MatchIterator` can also be converted into an iterator * that returns objects of type [[scala.util.matching.Regex.Match]], * such as is normally returned by `findAllMatchIn`. *  * Where potential matches overlap, the first possible match is returned, * followed by the next match that follows the input consumed by the * first match: * * {{{ * val hat = "hat[^a]+".r * val hathaway = "hathatthattthatttt" * val hats = (hat findAllIn hathaway).toList      // List(hath, hattth) * val pos = (hat findAllMatchIn hathaway map (_.start)).toList // List(0, 7) * }}} * * To return overlapping matches, it is possible to formulate a regular expression * with lookahead (`?=`) that does not consume the overlapping region. * * {{{ * val madhatter = "(h)(?=(at[^a]+))".r * val madhats = (madhatter findAllMatchIn hathaway map { * case madhatter(x,y) => s"$x$y" * }).toList          // List(hath, hatth, hattth, hatttt) * }}} * * Attempting to retrieve match information before performing the first match * or after exhausting the iterator results in [[java.lang.IllegalStateException]]. * See [[scala.util.matching.Regex.MatchIterator]] for details. * * @param source The text to match against. * @return  A [[scala.util.matching.Regex.MatchIterator]] of matched substrings. * @example  {{{for (words <- """/w+""".r findAllIn "A simple example.") yield words}}} */ def findAllIn(source: CharSequence) = new Regex.MatchIterator(source, this, groupNames)

Scala,正則表達式

 

模式匹配二

 //找到首個匹配項 println(numberPattern.findFirstIn("99ss java, 222 spark,333 hadoop"))

Scala,正則表達式

 

模式匹配三

//數(shù)字和字母的組合正則表達式 val numitemPattern="""([0-9]+) ([a-z]+)""".r val numitemPattern(num, item)="99 hadoop"

Scala,正則表達式

 

模式匹配四

 //數(shù)字和字母的組合正則表達式 val numitemPattern="""([0-9]+) ([a-z]+)""".r val line="93459 spark" line match{  case numitemPattern(num,blog)=> println(num+"/t"+blog)  case _=>println("hahaha...") }

Scala,正則表達式

 

val line="93459h spark" line match{  case numitemPattern(num,blog)=> println(num+"/t"+blog)  case _=>println("hahaha...") }

Scala,正則表達式

 

本節(jié)所有程序源碼

package kmust.hjr.learningScala19/** * Created by Administrator on 2015/10/17. */object RegularExpressOps { def main(args:Array[String]):Unit={ val regex="""([0-9]+)([a-z]+)""".r//"""原生表達 val numPattern="[0-9]+".r val numberPattern="""/s+[0-9]+/s+""".r //findAllIn()方法返回遍歷所有匹配項的迭代器 for(matchString <- numPattern.findAllIn("99345 Scala,22298 Spark"))  println(matchString) //找到首個匹配項 println(numberPattern.findFirstIn("99ss java, 222 spark,333 hadoop")) //數(shù)字和字母的組合正則表達式 val numitemPattern="""([0-9]+) ([a-z]+)""".r val numitemPattern(num, item)="99 hadoop" val line="93459h spark" line match{  case numitemPattern(num,blog)=> println(num+"/t"+blog)  case _=>println("hahaha...") } }}

Scala,正則表達式

總結(jié)

以上所述是小編給大家介紹的Scala中正則表達式以及與模式匹配結(jié)合(多種方式),希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!


注:相關(guān)教程知識閱讀請移步到正則表達式頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 和龙市| 柳河县| 新田县| 济源市| 汝南县| 肥乡县| 濮阳市| 西乌珠穆沁旗| 拉孜县| 梅州市| 靖边县| 蛟河市| 连云港市| 张家界市| 江西省| 阿拉善右旗| 菏泽市| 德格县| 利川市| 三明市| 侯马市| 靖远县| 台江县| 濉溪县| 吴桥县| 山阳县| 抚州市| 本溪| 万安县| 思茅市| 凉山| 涡阳县| 晋宁县| 沿河| 伽师县| 开远市| 靖宇县| 宜章县| 霍邱县| 横山县| 黑山县|