Dream------scala--Tuple、Array、Map与文件操作
1、Tuple(元组)
一般使用中,假设一个函数返回多个值,我们可以使用tuple接受这个(val (x,y) = myfunction)
package com.wls.scala.hello /**
* Created by wls on 2015年8月12日21:31:56.
*/
object TupleOps { def main(args : Array[String]): Unit ={
//可以放任意多个元素-------------scala一个强大能力,类型推到,可以根据值来判断变量的类型(比如:100他会识别为int,Spark他会识别为String)
val triple = (,"Spark","Scala")
//索引从1开始,不是从0开始
println(triple._1)
println(triple._2)
println(triple._3)
//输出:100
// Spark
// Scala
}
}
2、Array
object ArrayOperations {
//数组的声明
val array = Array(,,,,)
//数组的遍历(注意until和to的区别,to是闭区间,until是左闭右开)
for(i <- until array.length){
println(array(i))
}
//一般这个用的比较多
for(elem <- array){
println(elem)
}
}
3、Map
object MapOperations {
def main(args : Array[String]): Unit ={
//声明一个空的map
var myMap :Map[Int,String] = Map()
//给map赋值
myMap += ( -> "wlssss")
//声明一个初始化的map
val ages = Map("Rocky" -> ,"wls" -> )
//遍历map----(key,value)就可以看成是一个Tuple
for((key,value) <- ages){
println("Key is "+key +",value is "+ value)
}
//"_"是占位符,这种写法只能引用k,取不到value的
for((k,_) <- ages ){
println("Key is " + k)
}
}
}
4、文件
//需要引入这个包
import scala.io.Source /**
* Created by Administrator on 2015/8/12.
*/
object FileOps { def main(args : Array[String]): Unit ={
//读取本地文件
val file = Source.fromFile("E:/data/apache.org/index.html")
val fileURL = Source.fromURL("http://www.cnblogs.com/wangliansong/")
//按行读取文件,并输出,实际上就是输入文件内容,并且按原来的行格式
for(line <- file.getLines()){
println(line)
}
//会打印出这个网页的内容
for(lineURL <- fileURL.getLines()){
println(lineURL)
}
}
}
相关来源:
DT大数据梦工厂,微信公众号是:DT_Spark,每天都会有大数据实战视频发布,请您持续学习。
相关资料:
scala深入浅出实战经典完整视频、PPT、代码下载:
百度云盘:http://pan.baidu.com/s/1c0noOt6
腾讯微云:http://url.cn/TnGbdC
360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码45e2
Dream------scala--Tuple、Array、Map与文件操作的更多相关文章
- 003-Tuple、Array、Map与文件操作入门实战
003-Tuple.Array.Map与文件操作入门实战 Tuple 各个元素可以类型不同 注意索引的方式 下标从1开始 灵活 Array 注意for循环的until用法 数组的索引方式 上面的for ...
- [原创]Scala学习:Tuple,Array,Map ,文件操作
1.Tuple:元祖.是一个有用的容器对象. 1)特点: ① 元祖是不可变的,即,当声明完了一个元祖,那么它的长度就不可以在改变: ② 元祖可以包含不同类型的数据,对象: ③ 索引是从 '_1 ...
- Tuple,Array,Map,文件操作
Tuple是一个元组: 1,)一组元组中支持多个元素: 2,)一组元组中可以包含不同类型的元素: 3,)返回下标从_1开始. Array 数组 var items=Array(1,2,3,4) Map ...
- Scala编程入门---Map与Tuple
创建Map //创建一个不可变的Map val ages = Map("Leo" -> 30,"Jen" ->25,"Jack" ...
- scala简单的文件操作
1.scala写入文件操作 package com.test import java.io.File import java.io.PrintWriter /** * scala文件写入 */ obj ...
- Scala文件操作
Scala中的文件操作基本可以依赖于Java的实现,包括输入.输出流的使用. object FileOps {def main(args: Array[String]) { val file = So ...
- day3--集合、文件操作、字符编码与转换、函数(递归,lambda,filter,map)、字典排序
list1 = set([1, 2, 3, 4, 5, 6, 5, 5, 5])list2 = set([11, 2, 36, 'a', 5, 6, 5, 5, 5])list3 = set([1, ...
- scala map的常用操作
package cn.scala_base /** * map常用操作 */ object Map { def main(args: Array[String]): Unit = { //1.不可变m ...
- Scala 中Array,List,Tuple的差别
尽管学了一段时间的Scala了,可是总认为基础不是太扎实,还有非常多的基础知识比較模糊.于是近期又打算又一次学习基础. Scala中的三种集合类型包含:Array,List,Tuple.那么究竟这三种 ...
随机推荐
- ubuntu 16.04 部署 pypy+nginx+uwsgi+django(详细)
1.nginx ...
- GIT 旧库迁移到新库
1.在gitlab创建新项目,得到SSH地址2.用gitextent打开旧项目,记得所有分支合并成一个(如果确实无法合并,则需要一个个复位推送)3.复位到需要推送的节点分支4.打开菜单栏的档案库,管理 ...
- 【bzoj2806】 Ctsc2012—Cheat
http://www.lydsy.com/JudgeOnline/problem.php?id=2806 (题目链接) 题意 给出M个字符串组成“标准库”.定义L表示将一个字符串分成若干段,每一段的长 ...
- VIM 模板
Vim实现自动加载模版功能可以有很多的方法,比如利用插件和AutoCmd等.根据文件名自动加载模板的功能利用网上某大牛自己写的插件实现,我针对Java代码进行简单地修改,以实现模板中的Java主类类名 ...
- Java中JDK,JRE和JVM之间的关系
初学JAVA很容易被其中的很多概念弄的傻傻分不清楚,首先从概念上理解一下吧,JDK(Java Development Kit)简单理解就是Java开发工具包,JRE(Java Runtime Envi ...
- lumen 使用 dingo API 在 phpunit 中 404 的解决方法, 以及鉴权问题
1. phpunit.xml 中添加 dingo 相关配置 <env name="API_STANDARDS_TREE" value="x"/> & ...
- jsp的四大作用域
http://lavasoft.blog.51cto.com/62575/275586/ jsp中四个作用域的区别 JSP内置对象作用域表 名称 作用域 application 在所有应用程序中有效, ...
- Lvs+Keepalived实现MySQL高可用
LVS+Keepalived+MySQL高可用配置 本文所有配置前提是已实现MySQL双主备份(MySQL双主) 安装前的准备: VIP:192.168.0.201 Keepalived: Keepa ...
- MySQL数据库应用 从入门到精通 学习笔记
以下内容是学习<MySQL数据库应用 从入门到精通>过程中总结的一些内容提要,供以后自己复现使用. 一:数据库查看所有数据库: SHOW DATABASES创建数据库: CREATE DA ...
- Django 2.0.1 官方文档翻译: 如何安装 django (Page 17)
如何安装 django(Page 17) 这一部分可以让你将 Django 运行起来. 安装 Python 作为 python 的一个 web 框架,Django 依赖 Python.Python 的 ...