scala实例——三

import scala.util.control.Breaks._
import org.apache.spark.sql._
import org.apache.spark.SparkConf
import org.apache.spark.SparkContext
import org.apache.spark.sql.{DataFrame, SQLContext, SparkSession}
import org.apache.spark.rdd.RDD
import org.apache.spark.sql.execution.vectorized.ColumnarBatch.Row

import scala.util.Random
import scala.util.control.Breaks




object leave_analyse {

  def main(args: Array[String]) {
    val spark = SparkSession
      .builder()
      .appName("leave_analyse")
      .config("spark.some.config.option", "some-value")
      .getOrCreate()
    import spark.implicits._
    val df = spark.read.json("/spark_data/visit_records.json")
    df.createOrReplaceTempView("visit")
    // Global temporary view is tied to a system preserved database `global_temp`
    var result_string = ""


    var sql = "SELECT  out_time from visit  order by `in_time`  limit 1"
    var min_time = (spark.sql(sql).collect()) (0).asInstanceOf[Row].getInt(0)
    sql = "SELECT  out_time from visit  order by `in_time` desc  limit 1 "
    var max_time = (spark.sql(sql).collect()) (0).asInstanceOf[Row].getInt(0)
    var now_time = 0;

    var outer = new Breaks

    now_time = min_time;

    while (now_time <= max_time) {
      outer.breakable {
        var leave_num = 0;
        var time1 = now_time;
        var time2 = now_time + 300;

        var sql2 = "SELECT  count(*) num from visit   where `out_time` >= " + time1 + " and `out_time` <= " + time2 + ""; //SQL语句
        leave_num = (spark.sql(sql2).collect()) (0).asInstanceOf[Row].getInt(0)

        if (leave_num == 0) {
          now_time = now_time + 300;
          outer.break;
        }



        //每一条 jump 结果 添加到 结果集
        var leave_string = """{"time":"""+time1 +","+""""num":"""+leave_num+"}\n"
        result_string = result_string + leave_string


        now_time = now_time + 300;
      }

    }



    //将结果集 存入 文件
    import java.io._
    val writer = new PrintWriter(new File("\\sparkdata\\leave_num.json" ))

    writer.write(result_string)
    writer.close()








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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值