5.3.4 案例实操

需求

  1. 数据结构:时间戳,省份,城市,用户,广告,字段使用空格分割。

     1516609143867 6 7 64 16
     1516609143869 9 4 75 18
     1516609143869 1 7 87 12
    

    下载数据

  2. 需求: 统计出每一个省份广告被点击次数的 TOP3

具体实现

步骤1: 把文件放入到 resources目录下

步骤2: 具体代码

package day03

/*
数据结构:时间戳,省份,城市,用户,广告 字段使用空格分割。

样本如下:
1516609143867 6 7 64 16
1516609143869 9 4 75 18
1516609143869 1 7 87 12

统计出每一个省份广告被点击次数的 TOP3
 */
object Practice {
    def main(args: Array[String]): Unit = {
        // 1. 初始化spark配置信息, 并建立到spark的连接
        val conf = new SparkConf().setAppName("Practice").setMaster("local[*]")
        val sc = new SparkContext(conf)
        // 2. 从文件中读取数据, 得到 RDD. RDD中存储的是文件的中的每行数据
        val lines: RDD[String] = sc.textFile("file://" + ClassLoader.getSystemResource("agent.log"))

        // 3. ((provice, ad), 1)
        val provinceADAndOne: RDD[((String, String), Int)] = lines.map(line => {
            val splits: Array[String] = line.split(" ")
            ((splits(1), splits(4)), 1)
        })
        // 4. 计算每个省份每个广告被点击的总次数
        val provinceADSum: RDD[((String, String), Int)] = provinceADAndOne.reduceByKey(_ + _)

        // 5. 将省份作为key,广告加点击数为value: (Province,(AD,sum))
        val provinceToAdSum: RDD[(String, (String, Int))] = provinceADSum.map(x => (x._1._1, (x._1._2, x._2)))

        // 6. 按照省份进行分组
        val provinceGroup: RDD[(String, Iterable[(String, Int)])] = provinceToAdSum.groupByKey()

        //7. 对同一个省份的广告进行排序, 按照点击数的降序
        val result: RDD[(String, List[(String, Int)])] = provinceGroup.mapValues {
            x => x.toList.sortBy(_._2)(Ordering.Int.reverse).take(3)
        }

        //8. 按照省份的升序展示最终结果
        result.sortBy(_._1).collect.foreach(println)

        // 9. 关闭连接
        sc.stop()

    }

}

使用倒推法:

=> [((pid, cid), 1), ((pid, cid), 1)]   reuceByKey
=> [(pid, cid), count), (pid, cid), count]  map
=> [pid, (cid, count), (cid, count)]  groupByKey
=> [pid, Iterable((cid, count), (cid, count), ...)]
Copyright © 尚硅谷大数据 2019 all right reserved,powered by Gitbook
该文件最后修订时间: 2019-04-22 13:17:14

results matching ""

    No results matching ""