scala入门编程笔记

脚本模式编程
object HelloWorld {
   def main(args: Array[String]) {
      println("Hello, world!") // prints Hello World
   }
}
基础语法
区分大小写 -  Scala是大小写敏感的,这意味着标识Hello 和 hello在Scala中会有不同的含义。
类名 - 对于所有的类名的第一个字母要大写。
如果需要使用几个单词来构成一个类的名称,每个单词的第一个字母要大写。
示例:class MyFirstScalaClass
方法名称 - 所有的方法名称的第一个字母用小写。
如果若干单词被用于构成方法的名称,则每个单词的第一个字母应大写。
示例:def myMethodName()
程序文件名 - 程序文件的名称应该与对象名称完全匹配。
保存文件时,应该保存它使用的对象名称(记住Scala是区分大小写),并追加“.scala”为文件扩展名。 (如果文件名和对象名称不匹配,程序将无法编译)。
示例: 假设“HelloWorld”是对象的名称。那么该文件应保存为'HelloWorld.scala“
def main(args: Array[String]) - Scala程序从main()方法开始处理,这是每一个Scala程序的强制程序入口部分。
换行符:
语句可以用分号(;)结束或换行符。分号在声明的结尾通常是可选的。
变量声明
var myVar : String = "Foo"
var myVar = 10;
val myVal = "Hello, Scala!";
val (myVar1: Int, myVar2: String) = Pair(40, "Foo")
函数定义:
def functionName ([list of parameters]) : [return type] = {
   function body
   return [expr]
}
def addInt( a:Int, b:Int ) : Int = {
      var sum:Int = 0
      sum = a + b
      return sum
   }
void函数
   def printMe( ) : Unit = {
      println("Hello, Scala!")
   }
def main(args: Array[String]) {
        printInt(b=5, a=7);
   }
   def printInt( a:Int, b:Int ) = {
      println("Value of a : " + a );
      println("Value of b : " + b );
   }
def main(args: Array[String]) {
        printStrings("Hello", "Scala", "Python");
   }
   def printStrings( args:String* ) = {
      var i : Int = 0;
      for( arg <- args ){
         println("Arg value[" + i + "] = " + arg );
         i = i + 1;
      }
   }
匿名函数
var inc = (x:Int) => x+1
var x = inc(7)-1
var mul = (x: Int, y: Int) => x*y
println(mul(3, 4))
柯里函数
def strcat(s1: String)(s2: String) = s1 + s2
def strcat(s1: String) = (s2: String) => s1 + s2
strcat("foo")("bar")   
对于date使用不同的message的值
def main(args: Array[String]) {
      val date = new Date
      val logWithDateBound = log(date, _ : String)


      logWithDateBound("message1" )
      Thread.sleep(1000)
      logWithDateBound("message2" )
      Thread.sleep(1000)
      logWithDateBound("message3" )
   }
   def log(date: Date, message: String)  = {
     println(date + "----" + message)
   }
定义数组
var z = Array("Zara", "Nuha", "Ayan")   
concat()方法来连接两个数组的例子
var myList1 = Array(1.9, 2.9, 3.4, 3.5)
var myList2 = Array(8.9, 7.9, 0.4, 1.5)
var myList3 =  concat( myList1, myList2)
集合
// Define List of integers.链表
val x = List(1,2,3,4)
val fruit: List[String] = List("apples", "oranges", "pears")
val nums: List[Int] = List(1, 2, 3, 4)
// Define a set.不同元素的集合
var x = Set(1,3,5,7)
// Define a map.键/值对
val x = Map("one" -> 1, "two" -> 2, "three" -> 3)
val colors = Map("red" -> "#FF0000", "azure" -> "#F0FFFF")
// Create a tuple of two elements.元组可以容纳不同类型的对象
val x = (10, "Scala")
val t = (1, "hello", Console)
// Define an option  Option[T] 提供了一种容器,用于给定类型的零个或一个元素
val x:Option[Int] = Some(5)
使用:::运算符或列表List.:::()方法或List.concat()方法来添加两个或多个列表
val fruit1 = "apples" :: ("oranges" :: ("pears" :: Nil))
val fruit2 = "mangoes" :: ("banana" :: Nil)
 var fruit = fruit1 ::: fruit2
 fruit = List.concat(fruit1, fruit2)
 创建统一列表包括相同的元素如下的零个或更多个拷贝的列表
 val fruit = List.fill(3)("apples") // Repeats apples three times.
 串联集合:
 val fruit1 = Set("apples", "oranges", "pears")
      val fruit2 = Set("mangoes", "banana")
      // use two or more sets with ++ as operator
      var fruit = fruit1 ++ fruit2
      println( "fruit1 ++ fruit2 : " + fruit )
      // use two sets with ++ as method
      fruit = fruit1.++(fruit2)
查找集合的共同值:
val num1 = Set(5,6,9,20,30,45)
      val num2 = Set(50,60,9,20,35,55)
      // find common elements between two sets
      println( "num1.&(num2) : " + num1.&(num2) )
      println( "num1.intersect(num2) : " + num1.intersect(num2) )
键值对添加到映射
A += ('I' -> 1)
A += ('J' -> 5)  
映射的基本操作:
val colors = Map("red" -> "#FF0000","azure" -> "#F0FFFF","peru" -> "#CD853F")
      println( "Keys in colors : " + colors.keys )
      println( "Values in colors : " + colors.values )
串联映射
val colors1 = Map("red" -> "#FF0000",
                        "azure" -> "#F0FFFF",
                        "peru" -> "#CD853F")
      val colors2 = Map("blue" -> "#0033FF",
                        "yellow" -> "#FFFF00",
                        "red" -> "#FF0000")
      // use two or more Maps with ++ as operator
      var colors = colors1 ++ colors2
      println( "colors1 ++ colors2 : " + colors )


      // use two maps with ++ as method
      colors = colors1.++(colors2)  
打印映射的键和值:
colors.keys.foreach{ i =>  
                           print( "Key = " + i )
                           println(" Value = " + colors(i) )}
检查映射中的键:
colors.contains( "red" )
访问的元组 t 的元素
val t = (4,3,2,1)
val sum = t._1 + t._2 + t._3 + t._4
遍历元组:
val t = (4,3,2,1)
      t.productIterator.foreach{ i =>println("Value = " + i )}
Option[T]是容器对于给定的类型的零个或一个元件
模式匹配
def main(args: Array[String]) {
      val capitals = Map("France" -> "Paris", "Japan" -> "Tokyo")
      println("show(capitals.get( "Japan")) : " +  
                                          show(capitals.get( "Japan")) )
      println("show(capitals.get( "India")) : " +  
                                          show(capitals.get( "India")) )
   }
     def show(x: Option[String]) = x match {
      case Some(s) => s
      case None => "?"
   }
使用getOrElse()来访问值或使用默认值
迭代器不是集合,而是一种由一个访问的集合之一的元素
next和hasNext

class Yiibai(val xc: Int, val yc: Int) {
   var x: Int = xc
   var y: Int = yc
   def move(dx: Int, dy: Int) {
      x = x + dx
      y = y + dy
      println ("Yiibai x location : " + x);
      println ("Yiibai y location : " + y);
   }
}
class Location(override val xc: Int, override val yc: Int,
   val zc :Int) extends Yiibai(xc, yc){
   var z: Int = zc


   def move(dx: Int, dy: Int, dz: Int) {
      x = x + dx
      y = y + dy
      z = z + dz
      println ("Yiibai x location : " + x);
      println ("Yiibai y location : " + y);
      println ("Yiibai z location : " + z);
   }
}
object Test {
   def main(args: Array[String]) {
      val loc = new Location(10, 20, 15);


      // Move to a new location
      loc.move(10, 10, 5);
   }
}   
判断与循环
def main (args: Array[String]) {
    println("Hello, world!")
    var x = 30;
    if( x < 20 ){
      println("This is if statement");
    }else{
      println("This is else statement");
    }
    println(addInt(1,2));
    while( x < 32 ){//while循环的关键点是循环可能不会永远运行
      println( "Value of x: " + x );
      x += 1;
    }
    do{
      println( "Value of xx: " + x );
      x = x + 1;
    }while( x < 33 )


    var a = 0;
    // for loop execution with a range
    for( a <- 1 to 10){
      println( "Value of a: " + a );
    }
    for( a <- 1 until 10){
      println( "Value of a: " + a );
    }


    var b = 0;
    // for loop execution with a range
    for( a <- 1 to 3; b <- 1 to 3){
      println( "Value of a: " + a );
      println( "Value of b: " + b );
    }


    val numList = List(1,2,3,4,5,6);
    // for loop execution with a collection
    for( a <- numList ){
      println( "Value of a: " + a );
    }
    for( a <- numList
         if a != 3; if a < 8 ){
      println( "Value of a: " + a );
    }


    // for loop execution with a yield
    val retVal = for{ a <- numList
                      if a != 3; if a < 8
    }yield a
    // Now print returned values using another loop.
    for( a <- retVal){
      println( "Value of a: " + a );
    }
  }
  def addInt( a:Int, b:Int ) : Int = {
    var sum:Int = 0
    sum = a + b
    return sum
  }
模式匹配包括替代的序列,每个开始使用关键字case
 def main(args: Array[String]) {
      println(matchTest("two"))
      println(matchTest("test"))
      println(matchTest(1))
   }
   def matchTest(x: Any): Any = x match {
      case 1 => "one"
      case "two" => 2
      case y: Int => "scala.Int"
      case _ => "many"
   }
正则表达式
val pattern = "Scala".r   //调用r()方法 字符串隐式转换为一个RichString并调用该方法来获得正则表达式的一个实例
val str = "Scala is Scalable and cool"
println(pattern findFirstIn str)
val pattern = new Regex("(S|s)cala")  //a|b 匹配a或b。
val str = "Scala is scalable and cool"
println((pattern findAllIn str).mkString(","))
更换匹配的文本,可以使用replaceFirstIn()以取代第一个匹配项或replaceAllIn()
val pattern = "(S|s)cala".r
val str = "Scala is scalable and cool"
println(pattern replaceFirstIn(str, "Java"))
. 匹配除了换行符的任何字符
[Rr]uby 匹配 "Ruby" 或"ruby"    [...] 匹配括号内任何单个字符。
rub[ye] 匹配"ruby" 或 "rube"
[aeiou] 匹配任何一个小写元音
[0-9] 匹配任何数字;同 [0123456789]
[a-z] 匹配任意小写ASCII字母
[A-Z] 匹配任意大写ASCII字母
[a-zA-Z0-9] 匹配任何上述
[^aeiou] 匹配元音以外的任何一个小写字符   [^...] 匹配任何单个字符不是在括号中
[^0-9] 匹配数字以外的任何其他
d 匹配一个数字: [0-9]
D 匹配一个非数字: [^0-9]
s 匹配一个空白字符: [ f]
S 匹配非空白: [^ f]
w 匹配一个字符: [A-Za-z0-9_]
W 匹配 一个非单词字符: [^A-Za-z0-9_]
ruby? 匹配 "rub" or "ruby": the y is optional  re? 匹配0或1发生前表达式。
ruby* 匹配 "rub" plus 0 or more ys
ruby+ 匹配 "rub" plus 1 or more ys
d{3} 匹配只有 3 个数字   d 匹配数字。相当于 [0-9]. re{ n} 精确匹配n个前面表达式的数量。
d{3,} 匹配 3 个或多个数字  re{ n,} 匹配n或多次出现前面的表达。
d{3,5} 匹配3, 4, 或5 个数字  re{ n, m} 至少匹配n和在前面的表现最为m次出现。
Dd+ 不分组: + repeats d   re+ 匹配1个或多个的先前东西
(Dd)+/ 分组: + repeats Dd 对  D 匹配非数字。(re) 组正则表达式并记住匹配的文本
([Rr]uby(, )?)+ 匹配 "Ruby", "Ruby, ruby, ruby", 等


抛出异常
throw new IllegalArgumentException
try {
         val f = new FileReader("input.txt")
      } catch {
         case ex: FileNotFoundException =>{
            println("Missing file exception")
         }
文件I/O
写入文件
val writer = new PrintWriter(new File("test.txt" ))
writer.write("Hello Scala")
writer.close()
从屏幕读取一行:
print("Please enter your input : " )
val line = Console.readLine
println("Thanks, you just typed: " + line)
读取文件内容
Source.fromFile("test.txt" ).foreach{ 
         print 
      }

你可能感兴趣的:(scala,spark)