前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >酷炫的一行代码 - Scala就是这么任性!

酷炫的一行代码 - Scala就是这么任性!

作者头像
joymufeng
发布2018-05-17 15:21:12
7690
发布2018-05-17 15:21:12
举报

1. 过滤出序列中所有偶数

filter方法会将序列中各个元素依次替换到下划线"_"所处位置,如果返回true,则保留该元素。

代码语言:javascript
复制
(1 to 9).filter( _ % 2 == 0 )

输出:2, 4, 6, 8 

2. 对序列中所有元素求和

reduceLeft是一个通用的聚集计算方法,你可以把"+"换成其它的运算。其实对于求和有更简单的方法,请参考第6条。

代码语言:javascript
复制
(1 to 9).reduceLeft(_ + _)

输出:45

3. 统计单词出现次数

groupBy方法可以将序列转换成Map,适合用在需要按某个属性进行统计的情况。

代码语言:javascript
复制
List("no", "zuo", "no", "die").groupBy(w => w).mapValues(_.length)

输出:Map(no -> 2, zuo -> 1, die -> 1)

4. 将序列中单词首字母大写

map可以把序列转换成另一个序列,在map方法中定义各个元素的转换过程。

代码语言:javascript
复制
List("one", "line", "of", "code").map(_.capitalize)

输出:List(One, Line, Of, Code)

5. 将序列拼接成字符串 

mkString方法用于将序列拼接成字符串,第1个参数是起始符号,第2个参数是分隔符,第3个参数是结束符号。

代码语言:javascript
复制
(1 to 9).mkString("(", ",", ")")

输出:(1,2,3,4,5,6,7,8,9)

6. 最大值,最小值和求和 

这在Scala中轻而易举,直接调用min,max和sum方法。

代码语言:javascript
复制
List(14, 35, -7, 46, 98).min 
List(14, 35, -7, 46, 98).max 
List(14, 35, -7, 46, 98).sum

输出:-7 98 186

7. 获取序列中最大的前3个数值和位置

zipWithIndex方法将序列List[Int]转换成List[(Int, Int)],即List[Tuple2[Int, Int]]。Tuple2的第1个Int是元素,第2个Int是元素所处的位置。

代码语言:javascript
复制
List(2, 0, 1, 4, 12, 5).zipWithIndex.sorted.reverse.take(3)

输出:List((12,4), (5,5), (4,3))

8. 读取文本文件 

在Scala中读取文本文件相当轻松。

代码语言:javascript
复制
val fileContent = io.Source.fromFile("myfile.txt").mkString
val fileLines = io.Source.fromFile("myfile.txt").getLines.toList

9. 下载URL链接

下载文件就是这么容易。其实利用sys.process包,我们可以用Scala编写Shell脚本,是不是很酷!

代码语言:javascript
复制
import sys.process._
import java.net.URL
import java.io.File
new URL("http://www.oschina.net/favicon.ico") #> new File("d:/favicon.ico") !!

10. 并行计算

par方法将原序列转换成并行序列,可以利用多核的优势加快处理速度,真是想得太周到了!

代码语言:javascript
复制
(1 to 99).par.sum

输出:4950 

11. 两个List相乘求和

    类似加权求和。

代码语言:javascript
复制
dataList.zip(weightList).map{t => t._1 * t._2}.sum

12. 按多个字段排序List

先按学生的年龄排序,如果年龄相同,则按分数排序:

代码语言:javascript
复制
    case class Student(name: String, age: Int, score: Int)
    List(
      Student("a", 14, 60), 
      Student("b", 15, 80), 
      Student("a", 15, 70)
    ).sortBy(s => (s.age, s.score))

输出:List(Student(a,14,60), Student(a,15,70), Student(b,15,80))

13. 将List相邻元素分组

每相邻的10个元素分成一组:

代码语言:javascript
复制
val list = (0 to 20).map(_.toString)
list.zipWithIndex.map(t => t._1 -> ((t._2 / 10) * 10)).groupBy(_._2).toList.sortBy(_._1).map(_._2.map(_._1))

输出:

代码语言:javascript
复制
Vector(0, 1, 2, 3, 4, 5, 6, 7, 8, 9)
Vector(10, 11, 12, 13, 14, 15, 16, 17, 18, 19)
Vector(20)

14. 取序列的第1个元素

代码语言:javascript
复制
List(1, 2, 3).headOption.getOrElse(0)
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 过滤出序列中所有偶数
  • 2. 对序列中所有元素求和
  • 3. 统计单词出现次数
  • 4. 将序列中单词首字母大写
  • 5. 将序列拼接成字符串 
  • 6. 最大值,最小值和求和 
  • 7. 获取序列中最大的前3个数值和位置
  • 8. 读取文本文件 
  • 9. 下载URL链接
  • 10. 并行计算
  • 11. 两个List相乘求和
  • 12. 按多个字段排序List
  • 13. 将List相邻元素分组
  • 14. 取序列的第1个元素
相关产品与服务
GPU 云服务器
GPU 云服务器(Cloud GPU Service,GPU)是提供 GPU 算力的弹性计算服务,具有超强的并行计算能力,作为 IaaS 层的尖兵利器,服务于深度学习训练、科学计算、图形图像处理、视频编解码等场景。腾讯云随时提供触手可得的算力,有效缓解您的计算压力,提升业务效率与竞争力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档