方法一: a.第一步:在job中載入兩個文件所在的位置 FileInputFormat.setInputPaths(job, new Path[] { new Path("hdfs://192.168.9.13:8020/gradeMarking"), new Path("hdfs://192.16 ...
方法一:
a.第一步:在job中載入兩個文件所在的位置
FileInputFormat.setInputPaths(job, new Path[] { new Path("hdfs://192.168.9.13:8020/gradeMarking"),
new Path("hdfs://192.168.9.13:8020/implyCount") });
b.第二步:在Mapper類中重寫setup方法,使用context對象獲取該文件所在的文件名(如果是經過處理後的數據文件,因為文件名一樣part-r-00000,所以要獲取其所在的文件夾名)
@Override
protected void setup(Mapper<Text, Text, Text, Text>.Context context) throws IOException, InterruptedException {
FileSplit fs = (FileSplit) context.getInputSplit();
parentName = fs.getPath().getParent().getName();
}
方法二:
a.第一步:在job中將文件載入到本地
job.addCacheFile(new URI("hdfs://192.168.9.13:8020/meanwhileFind(同現)_data/part-r-00000"));
b.第二步:在Mapper函數中重寫setup函數,用字元緩衝流進行讀取
1 @Override 2 protected void setup(Mapper<LongWritable, Text, Text, Sort>.Context context) 3 throws IOException, InterruptedException { 4 @SuppressWarnings("resource") 5 BufferedReader br = new BufferedReader(new FileReader("part-r-00000")); 6 String str = null; 7 while ((str = br.readLine()) != null) { 8 String[] datas = str.split("\t"); 9 String[] sp = datas[0].split("-"); 10 if (!map.containsKey(sp[0])) { 11 HashMap<String, Double> mapInner = new HashMap<>(); 12 mapInner.put(sp[1], Double.parseDouble(datas[1])); 13 map.put(sp[0], mapInner); 14 } else { 15 @SuppressWarnings("rawtypes") 16 HashMap mapInner = map.get(sp[0]); 17 mapInner.put(sp[1], Double.parseDouble(datas[1])); 18 } 19 } 20 }