站長(zhǎng)資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

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

正則表達(dá)式

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

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

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

模式匹配一

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

說(shuō)明:findAllIn(…)函數(shù)簡(jiǎn)介

  /** 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中正則表達(dá)式以及與模式匹配結(jié)合(多種方式)

模式匹配二

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

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

模式匹配三

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

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

模式匹配四

   //數(shù)字和字母的組合正則表達(dá)式   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中正則表達(dá)式以及與模式匹配結(jié)合(多種方式)

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

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

本節(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//"""原生表達(dá)   val numPattern="[0-9]+".r   val numberPattern="""s+[0-9]+s+""".r   //findAllIn()方法返回遍歷所有匹配項(xiàng)的迭代器   for(matchString <- numPattern.findAllIn("99345 Scala,22298 Spark"))    println(matchString)   //找到首個(gè)匹配項(xiàng)   println(numberPattern.findFirstIn("99ss java, 222 spark,333 hadoop"))   //數(shù)字和字母的組合正則表達(dá)式   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中正則表達(dá)式以及與模式匹配結(jié)合(多種方式)

總結(jié)

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

贊(0)
分享到: 更多 (0)
網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
国产成人精品18| 色妞ww精品视频7777| 日韩精品人成在线播放| 亚洲国产精品精华液| 1204国产成人精品视频| 国产成人亚洲精品青草天美| 久久久久久极精品久久久| 日韩av一中美av一中文字慕| 日韩成人在线视屏| 日韩亚洲综合精品国产| 亚洲国产成人精品无码区花野真一| 在线人成精品免费视频| 久久国产精品61947| 亚洲精品一品区二品区三品区| 国产精品免费久久久久影院| 亚洲AV日韩AV一区二区三曲| 加勒比精品久久一区二区三区| 精品免费国产一区二区三区| 亚洲精品无播放器在线播放| 国产成人精品综合网站| 亚洲国产精品线观看不卡| 久久精品国产亚洲77777| 亚洲综合精品香蕉久久网97| 日本久久久精品中文字幕| 最新精品露脸国产在线| 国产无套精品一区二区| 国内精品久久久久久久影视麻豆| chinese精品男同志浪小辉| 午夜三级国产精品理论三级 | 国产精品最新国产精品第十页| 麻豆人妻少妇精品无码专区| 老司机精品视频免费| 日韩精品一区二区三区中文版 | 人妻少妇精品无码专区动漫| 97精品人妻系列无码人妻| 四虎精品视频在线永久免费观看| 2021国产精品久久| 久久精品国产久精国产一老狼| 91人前露出精品国产| 精品无码久久久久国产动漫3d| 日韩精品一区二区三区老鸭窝|