首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >列出美国国家航空公司mapreduce的所有航空公司

列出美国国家航空公司mapreduce的所有航空公司
EN

Stack Overflow用户
提问于 2016-01-14 16:13:46
回答 2查看 151关注 0票数 0

下面的mapreduce代码是为了获得以下输出而编写的:

“普林斯顿航空公司”“优先航空租赁”“优先空运”“优先航空公司”“私人飞机远征”“私人飞机管理”

代码:

代码语言:javascript
运行
复制
import java.io.IOException;

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.Mapper;
import org.apache.hadoop.mapreduce.Reducer;
import org.apache.hadoop.mapreduce.lib.input.FileInputFormat;
import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat;

public class UScountry {

    public static class mymapper extends Mapper<Object,Text,Text,Text>{

        protected void map(Object key,Text value,Context context) throws IOException, InterruptedException{

            String data[]=value.toString().split(",");
            CharSequence c="united states";
            if(data[6].toLowerCase().contains(c)){
                context.write(new Text(data[1]),new Text("") );
            }
        }
    }

    public static void main(String args[]) throws IOException, ClassNotFoundException, InterruptedException
    {
        Configuration conf=new Configuration();
        Job job=Job.getInstance(conf,"US");
        job.setJarByClass(UScountry.class);
        job.setMapperClass(mymapper.class);
        job.setMapOutputKeyClass(Text.class);
        job.setMapOutputValueClass(Text.class);
        job.setOutputKeyClass(Text.class);
        job.setOutputValueClass(Text.class);
        FileInputFormat.addInputPath(job, new Path(args[0]));
        FileOutputFormat.setOutputPath(job, new Path(args[1]));
        job.waitForCompletion(true);
    }



}

但是,代码提供的输出是:

“普林斯顿航空公司”0 “优先航空宪章”0 “优先空运”0 “优先航空公司”0 “私人飞机远征”0 “私人飞机管理”0

请帮我找出我哪里出了问题!

输入文件是:

1、“特权样式L”、\N、"“、"PVG”、“特权”、“西班牙”、"N“ 2,“普林斯顿航空公司”,\N,"","PCN",“普林斯顿”,“美国”,"N“ 3、“优先航空宪章”、\N、"“、”撬“、”优先飞行“、”美国“、"N” 4、“优先空运”、\N、"“、"PAT”、"PAT“、”美国“、"N” 5、“优先航空公司”、\N、"“、"BCK”、"BANKCHECK“、”美国“、"N” 6、"Privatair“、\N、"”、"PTI“、"PRIVATAIR”、“瑞士”、"Y“ 7、“私人喷气式远征”、\N、"PJE“、"PEE JAY”、"United States“、"N” 8、“私人飞机管理”、\N、"PJA“、”私人航班“、”美国“、"N” 9、“私人翼”、"N“、"8W”、"PWF“、”私人翅膀“、”德国“、”N“

EN

回答 2

Stack Overflow用户

发布于 2016-01-14 17:26:00

您可以为输出值类设置NullWritable.class

代码语言:javascript
运行
复制
job.setOutputValueClass(NullWritable.class);

这将抑制减速器输出的值部分,即输出中的0。

票数 1
EN

Stack Overflow用户

发布于 2016-01-14 16:26:18

试着改变:

代码语言:javascript
运行
复制
context.write(new Text(data[1]),new Text("") );

对此:

代码语言:javascript
运行
复制
context.write(new Text(data[1]));
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34794360

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档