池清煜 2021-12-17 00:13 采纳率: 100%
浏览 43
已结题

MapReduce平均数成绩怎么求每行的平均数

img

  • 写回答

1条回答 默认 最新

  • MelodyYN 2021-12-17 08:50
    关注
    
    package com.hpu.hadoop.test;
    
    import org.apache.hadoop.io.DoubleWritable;
    import org.apache.hadoop.io.LongWritable;
    import org.apache.hadoop.io.Text;
    import org.apache.hadoop.mapreduce.Mapper;
    
    import java.io.IOException;
    
    public class MyMapper extends Mapper<LongWritable, Text,Text, DoubleWritable> {
        private Text K;
        private DoubleWritable V;
    
        @Override
        protected void setup(Context context) throws IOException, InterruptedException {
            K = new Text();
            V = new DoubleWritable();
        }
    
        @Override
        protected void map(LongWritable key, Text value, Context context) throws IOException, InterruptedException {
            String[] split = value.toString().split("\t");
            K.set(split[0]);
            double sum = Double.parseDouble(split[1]) + Double.parseDouble(split[2]) + Double.parseDouble(split[3]);
            V.set(sum/3);
            context.write(K,V);
        }
    }
    
    
    package com.hpu.hadoop.test;
    
    import org.apache.hadoop.conf.Configuration;
    import org.apache.hadoop.fs.Path;
    import org.apache.hadoop.io.DoubleWritable;
    import org.apache.hadoop.io.Text;
    import org.apache.hadoop.mapreduce.Job;
    import org.apache.hadoop.mapreduce.lib.input.FileInputFormat;
    import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat;
    
    import java.io.IOException;
    
    
    public class MyDriver {
        public static void main(String[] args) throws IOException, ClassNotFoundException, InterruptedException {
            Configuration conf = new Configuration();
            Job job = Job.getInstance(conf);
    
            job.setJarByClass(MyDriver.class);
            job.setMapperClass(MyMapper.class);
            job.setNumReduceTasks(0);
    
            job.setMapOutputKeyClass(Text.class);
            job.setMapOutputValueClass(DoubleWritable.class);
    
            job.setOutputKeyClass(Text.class);
            job.setOutputValueClass(DoubleWritable.class);
            //指定输入、输出路径
            FileInputFormat.setInputPaths(job,new Path(""));
            FileOutputFormat.setOutputPath(job,new Path(""));
    
            boolean b = job.waitForCompletion(true);
            System.exit(b?0:1);
    
        }
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 12月25日
  • 已采纳回答 12月17日
  • 创建了问题 12月17日

悬赏问题

  • ¥15 求京东批量付款能替代天诚
  • ¥15 slaris 系统断电后,重新开机后一直自动重启
  • ¥15 51寻迹小车定点寻迹
  • ¥15 谁能帮我看看这拒稿理由啥意思啊阿啊
  • ¥15 关于vue2中methods使用call修改this指向的问题
  • ¥15 idea自动补全键位冲突
  • ¥15 请教一下写代码,代码好难
  • ¥15 iis10中如何阻止别人网站重定向到我的网站
  • ¥15 滑块验证码移动速度不一致问题
  • ¥15 Utunbu中vscode下cern root工作台中写的程序root的头文件无法包含