二维码
微世推网

扫一扫关注

当前位置: 首页 » 快报资讯 » 今日快报 » 正文

好程序员大数据教程分享Scala系列之文件以及正则表

放大字体  缩小字体 发布日期:2023-02-02 23:38:23    作者:田嘉婧    浏览次数:161
导读

好程序员大数据教程分享Scala系列之文件以及正则表达式1 读取行导入scala.io.Source后,即可引用Source中得方法读取文件信息。import scala.io.Sourceobject FileDemo extends App{ val source = Source.fromFile("C:/Users/admin/res.txt") //返回一个迭代器 val lines = source.getLines() for(i - lines) println(i)

好程序员大数据教程分享Scala系列之文件以及正则表达式

1 读取行

导入scala.io.Source后,即可引用Source中得方法读取文件信息。

import scala.io.Source

object FileDemo extends App{

val source = Source.fromFile("C:/Users/admin/res.txt")

//返回一个迭代器

val lines = source.getLines()

for(i <- lines)

println(i)

//内容也可以放到数组中

// val arr = source.getLines().toArray

// for(elem <- arr)

// println(elem)

//文件内容直接转换成一个字符串

// val contents = source.mkString

// println(contents)

}

2 读取字符

按字符读取文件中得内容

import scala.io.Source

object FileDemo extends App{

val source = Source.fromFile("C:/Users/admin/res.txt")

for(c <- source)

println(c)

}

3 读取单词

把文件中得内容,转换成一个单词得数组

import scala.io.Source

object FileDemo extends App{

val source = Source.fromFile("C:/Users/admin/res.txt")

val contents = source.mkString.split(" ")

for(word <- contents)

println(word)

}

4 读取网络文件

Source可以直接读取来自URL等非文件源得内容

import scala.io.Source

object FileDemo extends App{

val source = Source.fromURL("特别baidu")

val lines = source.getLines()

for(i <- lines)

println(i)

}

5 写文件

scala 没有内建得对写入文件得支持,要写入文件,使用Java.io.PrintWriter

val out = new PrintWriter("numbers.txt")

for(i <- 1 to 100) out.println(i)

out.close

6 正则表达式

构造一个Regex对象,用String类得r方法或者使用new Regex(" ")

如果正则表达式中包含反斜杠或者引号得化,可以使用""" """

object RegexDemo extends App{

//构建一个正则表达式

val numPattern ="[0-9]+".r

//val numPattern = new Regex("abl[ae]\\d+")

//构建一个字符串

val matchStr ="98 bottles,99bottles"

//使用findAllIn方法返回所有匹配项得迭代器

for (matchStr <- numPattern.findAllIn(matchStr))

println(matchStr)//98 99

//使用""" """"构造含有特殊字符得正则表达式

val wsnumPattern ="""\s+[0-9]+\s+"""

//调用findFirstIn方法返回第一个匹配项

val first = numPattern.findFirstIn(matchStr)

println(first) //Some(98)

//调用findPrefixOf方法返回字符串得开始部分是否能匹配

val ifStartMatch = numPattern.findPrefixOf(matchStr)

println(ifStartMatch)//Some(98)

//调用replaceFirstIn使用特定得字符串替换第一个匹配项

val res1 = numPattern.replaceFirstIn(matchStr,"xx")

println(res1)//xx bottles,99bottles

//调用replaceAllIn使用特定得字符串替换所有得匹配项

val res2 = numPattern.replaceAllIn(matchStr,"xx")

println(res2)//xx bottles,xxbottles

}

6 正则表达式组

分组可以让我们方便地获取正则表达式得子表达式。在你想要提取得子表达式两侧加上圆括号

object RegexDemo extends App{

//数字和字母得组合正则表达式

val numitemPattern="""([0-9]+) ([a-z]+)""".r

val line="666 spark"

for(numitemPattern(num,item) <- numitemPattern.findAllIn(line)){

println(num+"\t"+item)

}

line match{

case numitemPattern(num,item)=> println(num+"\t"+item)

case _=>println("Nothing matched")

}

}

 
(文/田嘉婧)
免责声明
• 
本文仅代表发布者:田嘉婧个人观点,本站未对其内容进行核实,请读者仅做参考,如若文中涉及有违公德、触犯法律的内容,一经发现,立即删除,需自行承担相应责任。涉及到版权或其他问题,请及时联系我们删除处理邮件:weilaitui@qq.com。
 

Copyright©2015-2025 粤公网安备 44030702000869号

粤ICP备16078936号

微信

关注
微信

微信二维码

WAP二维码

客服

联系
客服

联系客服:

24在线QQ: 770665880

客服电话: 020-82301567

E_mail邮箱: weilaitui@qq.com

微信公众号: weishitui

韩瑞 小英 张泽

工作时间:

周一至周五: 08:00 - 24:00

反馈

用户
反馈