scala正则

package Demo001.scala02

object RegexDemo extends App {


  //"2019-04-11"
  //三个双引号为自然语言不用\转义 等同于 "(\\d\\d\\d\\d)-(\\d\\d)-(\\d\\d)".r
  val data1="""(\d\d\d\d)-(\d\d)-(\d\d)""".r //.r的返回值是Regex 就是正则表达式的意思

  val x="2019-04-11" match {

      case data1(x,y,z) => (x,y)//可以根据需求拿出年月 (2019,04)
      case _ =>("Hello Regex")
  }
  println(x)
//===========weblog Regex
  val webLog = "110.52.250.126 - - [30/May/2013:17:38:20 +0800]"
  val webRegex="""(\d\d\d.\d\d.\d\d\d.\d\d\d)\D\D(\d\d/\D\D\D/\d\d\d\d:\d\d:\d\d:\d\d+\d\d\d\d)""".r

  webLog match {

    case webRegex => println(webRegex)
  }
//=====================weblog Regex
  val dates = "Important dates in history: 2004-01-20, 1958-09-05, 2010-10-06, 2011-07-15"
  //findFirstIn和findFirstMatchIn是值匹配到第一个成功匹配的数据.
  val firstdata=data1.findFirstIn(dates)
  val firstyear=for(m <- data1 findFirstMatchIn dates) yield m group 1 //findfirstmatchin 底层用的是options集合所以返回的是some
  println(firstdata)//Some(2004-01-20)
  println(firstyear)//Some(2004)


  for(g <- data1 findAllMatchIn(dates))println(g.subgroups)//相当于把全部符合类型的数组返回
  //List(2004, 01, 20)
//  List(1958, 09, 05)
//  List(2010, 10, 06)
//  List(2011, 07, 15


}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值