AWS Hadoop MapReduce - Word Count Average(AWS Hadoop MapReduce - 单词计数平均值)
创始人
2024-11-16 09:30:52
0

以下是使用AWS Hadoop MapReduce解决Word Count Average问题的示例代码:

Mapper类:

import java.io.IOException;
import org.apache.hadoop.io.IntWritable;
import org.apache.hadoop.io.Text;
import org.apache.hadoop.mapreduce.Mapper;

public class WordCountMapper extends Mapper {

    private final static IntWritable one = new IntWritable(1);
    private Text word = new Text();

    public void map(Object key, Text value, Context context) throws IOException, InterruptedException {
        String[] words = value.toString().split(" ");
        for (String word : words) {
            this.word.set(word);
            context.write(this.word, one);
        }
    }
}

Reducer类:

import java.io.IOException;
import org.apache.hadoop.io.IntWritable;
import org.apache.hadoop.io.Text;
import org.apache.hadoop.mapreduce.Reducer;

public class WordCountReducer extends Reducer {

    private IntWritable result = new IntWritable();

    public void reduce(Text key, Iterable values, Context context)
            throws IOException, InterruptedException {
        int sum = 0;
        int count = 0;
        for (IntWritable value : values) {
            sum += value.get();
            count++;
        }
        int average = sum / count;
        result.set(average);
        context.write(key, result);
    }
}

Driver类:

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.Path;
import org.apache.hadoop.io.IntWritable;
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;

public class WordCountAverage {

    public static void main(String[] args) throws Exception {
        Configuration conf = new Configuration();
        Job job = Job.getInstance(conf, "word count average");
        job.setJarByClass(WordCountAverage.class);
        job.setMapperClass(WordCountMapper.class);
        job.setCombinerClass(WordCountReducer.class);
        job.setReducerClass(WordCountReducer.class);
        job.setOutputKeyClass(Text.class);
        job.setOutputValueClass(IntWritable.class);
        FileInputFormat.addInputPath(job, new Path(args[0]));
        FileOutputFormat.setOutputPath(job, new Path(args[1]));
        System.exit(job.waitForCompletion(true) ? 0 : 1);
    }
}

请注意,上述代码仅为示例,您需要根据您的实际需求进行适当的更改和配置。此示例假定输入文件中的每个单词以空格分隔,并且每个单词都位于单独的行中。

相关内容

热门资讯

据玩家消息!杭州都莱辅助软件,... 据玩家消息!杭州都莱辅助软件,皮皮跑子胡子修改器-其实真的有辅助脚本(哔哩哔哩)1、皮皮跑子胡子修改...
现场直击!越乡游义乌辅助器微信... 现场直击!越乡游义乌辅助器微信,新玄龙辅助-竟然是有辅助挂(哔哩哔哩);所有人都在同一条线上,像星星...
今年以来!欢乐达人暗堡链接脚本... 今年以来!欢乐达人暗堡链接脚本,哈糖大菠萝辅助器-好像真的是有辅助app(哔哩哔哩)1、不需要AI权...
今天上午!潮友汇俱乐部辅助器下... 今天上午!潮友汇俱乐部辅助器下载,情怀宜春辅助-切实真的是有辅助神器(哔哩哔哩)1、完成潮友汇俱乐部...
最新消息!南通长牌辅助,心悦填... 最新消息!南通长牌辅助,心悦填大坑辅助-确实存在有辅助挂(哔哩哔哩)心悦填大坑辅助辅助器是一种具有地...
透视辅助!天天互娱辅助器免费下... 透视辅助!天天互娱辅助器免费下载,禅游指尖四川修改器-本来是真的有辅助工具(哔哩哔哩)在进入天天互娱...
今天上午!微信雀神挂件辅助器,... 今天上午!微信雀神挂件辅助器,wepoker私人局辅助器-原来是真的有辅助方法(哔哩哔哩)1、完成微...
黑科技技巧!长了四人上品十三攻... 黑科技技巧!长了四人上品十三攻略,飞驰娱乐软件科技-一直真的有辅助教程(哔哩哔哩)运长了四人上品十三...
透视ai!竹间智能辅助助手,哈... 透视ai!竹间智能辅助助手,哈灵永久辅助-都是是真的有辅助器(哔哩哔哩)1、竹间智能辅助助手辅助器安...
据报道!兴动互娱修改器免费,胡... 据报道!兴动互娱修改器免费,胡乐辅助脚本-切实真的是有辅助软件(哔哩哔哩)1、完成兴动互娱修改器免费...