下面的MapReduce代碼寫入到輸出如下:列出所有從團結心滿意足航空公司的MapReduce程序
"Princeton Aviation Corporation"
"Priority Air Charter"
"Priority Air Transport" "Priority Aviation Company"
"Private Jet Expeditions" "Private Jet Management"
代碼:
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);
}
}
但輸出的代碼是給是:
"Princeton Aviation Corporation" 0
"Priority Air Charter" 0
"Priority Air Transport" 0
"Priority Aviation Company" 0
"Private Jet Expeditions" 0
"Private Jet Management" 0
請幫我找出我哪裏錯了!
輸入文件是:
1,"Privilege Style L",\N,"","PVG","PRIVILEGE","Spain","N"
2,"Princeton Aviation Corporation",\N,"","PCN","PRINCETON","United States","N"
3,"Priority Air Charter",\N,"","PRY","PRIORITY AIR","United States","N"
4,"Priority Air Transport",\N,"","PAT","PAT","United States","N"
5,"Priority Aviation Company",\N,"","BCK","BANKCHECK","United States","N"
6,"Privatair",\N,"","PTI","PRIVATAIR","Switzerland","Y"
7,"Private Jet Expeditions",\N,"","PJE","PEE JAY","United States","N"
8,"Private Jet Management",\N,"","PJA","PRIVATE FLIGHT","United States","N"
9,"Private Wings Flugcharter",\N,"8W","PWF","PRIVATE WINGS","Germany","N"
它向我顯示錯誤:類型TaskInputOutputContext
這不起作用 - 'write'需要被賦予一個關鍵和一個價值。 –