Hadoop经典案例Spark实现(四)——平均成绩

本文介绍了如何运用Hadoop MapReduce框架,结合Spark实现计算平均成绩的案例。在Map阶段,数据经过partition处理后发送到Reducer。Reducer通过Context的write方法将最终结果写入文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Hadoop经典案例Spark实现(四)——平均成绩

一、案例分析:
1、需求分析
对输入文件中数据进行就算学生平均成绩。输入文件中的每行内容均为一个学生的姓名和他相应的成绩,如果有多门学科,则每门学科为一个文件。
要求在输出中每行有两个间隔的数据,其中,第一个代表学生的姓名,第二个代表其平均成绩。


2、原始数据
1)math:
张三    88
李四    99
王五    66
赵六    77

2)china:
张三    78
李四    89
王五    96
赵六    67

3)english:
张三    80
李四    82
王五    84
赵六    86

样本输出:
张三    82
李四    90
王五    82
赵六    76

3、设计思考
Map处理的 是一个纯文本文件, 文件中存放的数据时每一行表示一个学生的姓名和他相应一科成绩。Mapper处理的数据是由InputFormat分解过的数据集,
其中 InputFormat的作用是将数据集切割成小数据集InputSplit,每一个InputSplit将由一个Mapper负责处理。此 外,InputFormat中还提供了一个RecordReader的实现,
并将一个InputSplit解析成<key,value>对提 供给了map函数。InputFormat的默认值是TextInputFormat,它针对文本文件,按行将文本切割成InputSlit,
并用 LineRecordReader将InputSplit解析成<key,value>对,key是行在文本中的位置
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值