當前位置: 首頁>>代碼示例>>Java>>正文


Java MapWritable.keySet方法代碼示例

本文整理匯總了Java中org.apache.hadoop.io.MapWritable.keySet方法的典型用法代碼示例。如果您正苦於以下問題:Java MapWritable.keySet方法的具體用法?Java MapWritable.keySet怎麽用?Java MapWritable.keySet使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.hadoop.io.MapWritable的用法示例。


在下文中一共展示了MapWritable.keySet方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: convertToMap

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
private static Map<String, Map<String,String>> convertToMap(MapWritable inputMap) {
	Map<String, Map<String,String>> mapResult = Maps.newHashMap();
	
	for (Writable attributeText : inputMap.keySet()) {
		MapWritable partialInsideMap = (MapWritable) inputMap.get(attributeText);
		Map<String,String> partialOutputMap = Maps.newHashMap();
		
		for (Writable rule : partialInsideMap.keySet()) {
			Text regola = (Text) rule;
			Text valore = (Text) partialInsideMap.get(rule);
			
			partialOutputMap.put(regola.toString(), valore.toString());
		}
		
		mapResult.put(((Text)attributeText).toString(), partialOutputMap);
	}
	
	return mapResult;
}
 
開發者ID:disheng,項目名稱:alfred-mpi,代碼行數:20,代碼來源:MapWritableConverter.java

示例2: reduce

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
@Override
public void reduce(Text key, Iterable<MapWritable> listOfMaps, Context context) throws IOException, InterruptedException {

	for (MapWritable partialResultMap : listOfMaps) {
		for (Writable attributeText : partialResultMap.keySet()) {
			MapWritable partialInsideMap = (MapWritable) partialResultMap.get(attributeText);
			MapWritable partialOutputMap = new MapWritable();
			
			for (Writable rule : partialInsideMap.keySet()) {
				Text regola = (Text) rule;
				Text valore = (Text) partialInsideMap.get(rule);
				
				partialOutputMap.put(new Text(regola.toString()), new Text(valore.toString()));
			}
			
			result.put((Text)attributeText, partialOutputMap);
		}
	}
	
	Text resultWrite = new Text(MapWritableConverter.toJsonText(result));
	
	context.write(key,resultWrite);       
}
 
開發者ID:disheng,項目名稱:alfred-mpi,代碼行數:24,代碼來源:XPathApplierTextReducer.java

示例3: reduce

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
@Override
public void reduce(Text key, Iterable<MapWritable> listOfMaps, Context context) throws IOException, InterruptedException {

	for (MapWritable partialResultMap : listOfMaps) {
		for (Writable attributeText : partialResultMap.keySet()) {
			MapWritable partialInsideMap = (MapWritable) partialResultMap.get(attributeText);
			MapWritable partialOutputMap = new MapWritable();
			
			for (Writable rule : partialInsideMap.keySet()) {
				Text regola = (Text) rule;
				Text valore = (Text) partialInsideMap.get(rule);
				
				partialOutputMap.put(new Text(regola.toString()), new Text(valore.toString()));
			}
			
			result.put((Text)attributeText, partialOutputMap);
		}
	}
		
	context.write(key,result);       
}
 
開發者ID:disheng,項目名稱:alfred-mpi,代碼行數:22,代碼來源:XPathApplierReducer.java

示例4: mapWritableToString

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
/**
 * Method to convert a MapWritable into a JSON string
 * 
 */
@SuppressWarnings("unchecked")
public static String mapWritableToString(MapWritable map)
{
  // Convert to JSON and then write to a String - ensures JSON read-in compatibility
  JSONObject jsonObj = new JSONObject();
  for (Writable key : map.keySet())
  {
    jsonObj.put(key.toString(), map.get(key).toString());
  }

  return jsonObj.toJSONString();
}
 
開發者ID:apache,項目名稱:incubator-pirk,代碼行數:17,代碼來源:StringUtils.java

示例5: write

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
@Override
public void write(NullWritable key, Writable value) throws IOException {
	
  log.info("SolrRecordWriter ->  write");

	if(solr == null) {
    solr = SolrOperations.getSolrServer(conf);
	}

  SolrInputDocument doc = new SolrInputDocument();
  if(value.getClass().getName().equals("org.apache.hadoop.io.MapWritable")){
    MapWritable valueMap = (MapWritable) value;

    for(Writable keyWritable : valueMap.keySet()) {
      String fieldName = keyWritable.toString();
      Object fieldValue = valueMap.get(new Text(fieldName));
      // Need to add proper conversion of object to Schema field type
      doc.addField(fieldName, fieldValue.toString());
    }
  }
  else if(value.getClass().getName().equals("org.bigsolr.hadoop.SolrInputRecord")) {
    doc = (SolrInputDocument) value;
  }
  else {
    log.error("SolrRecordWriter write() Class for Value is not Supported: " + value.getClass().getName());
    System.exit(0);
  }
	
	try {
	  solr.add(doc);
	  //solr.commit(true,true);
	} catch (SolrServerException e) {
	  log.error("SolrRecordWriter-- solr.add(doc) failed");
    throw new IOException(e);
	}
	
}
 
開發者ID:mrt,項目名稱:bigsolr,代碼行數:38,代碼來源:SolrRecordWriter.java

示例6: es2Json

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
public JSONObject es2Json(MapWritable valueWritable) throws IOException, InterruptedException {
    JSONObject obj = new JSONObject();
    for (Writable keyWritable : valueWritable.keySet()) {
        String key = ((Text) keyWritable).toString();
        Writable valWritable = valueWritable.get(keyWritable);
        
        if (valWritable instanceof Text) {
            obj.put(key, valWritable.toString());
        } else if (valWritable instanceof IntWritable) {
            obj.put(key, ((IntWritable)valWritable).get());
        } else if (valWritable instanceof FloatWritable) {
            obj.put(key, ((FloatWritable)valWritable).get());
        } else if (valWritable instanceof LongWritable) {
            obj.put(key, ((LongWritable)valWritable).get());
        } else if (valWritable instanceof DoubleWritable) {
            obj.put(key, ((DoubleWritable)valWritable).get());
        } else if (valWritable instanceof BooleanWritable) {
            obj.put(key, ((BooleanWritable)valWritable).get());
        } else if (valWritable instanceof MapWritable) {
            obj.put(key, es2Json((MapWritable) valWritable));
        } else if (valWritable instanceof WritableArrayWritable) {
            WritableArrayWritable waw = (WritableArrayWritable) valWritable;
            Writable[] writable = waw.get();
            
            JSONArray array = new JSONArray();
            for (int i=0; i < writable.length; ++i) {
                Object o = writable[i];
                if (o instanceof MapWritable) {
                    array.add(es2Json((MapWritable) o));
                } else if (o instanceof Text) {
                    array.add(o.toString());
                } else if (o instanceof IntWritable) {
                    array.add(((IntWritable)o).get());
                } else if (o instanceof FloatWritable) {
                    array.add(((FloatWritable)o).get());
                } else if (o instanceof LongWritable) {
                    array.add(((LongWritable)o).get());
                } else if (o instanceof DoubleWritable) {
                    array.add(((DoubleWritable)o).get());
                }
            }
            obj.put(key, array);
        }
    }
    return obj;
}
 
開發者ID:chaopengio,項目名稱:elasticsearch-mapreduce,代碼行數:47,代碼來源:Es2Json.java

示例7: reduce

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
@Override
public void reduce(Text key, Iterable<MapWritable> values, Context context)
	throws IOException, InterruptedException
{
	// Let's have a map and internally collect them
	
	int maps = 0;
	int vals = 0;
			
	HashMap<Text, Integer> myMap = new HashMap<Text, Integer>(); 
	
	for (MapWritable m : values)
	{		
		maps++;
		for (Writable valName : m.keySet())
		{
			
			Text val = (Text) valName;
			Integer count = ((IntWritable)(m.get(valName))).get();
			if (myMap.containsKey(val))
			{
				myMap.put(val, myMap.get(val) + count);
			}
			else
			{
				myMap.put(val, count);
				vals++;
			}				
		}
	}
	
	s_logger.debug("Reducer/combiner got " + maps + 
				   " maps, with a total of " + vals + 
				   " distinct values for attribute `" + key + "`"); 
	
	// now output
	// key is key 
	// value is myMap as MapWritable<Text, IntWritable>
	
	MapWritable output = new MapWritable();		
	for (Text t : myMap.keySet())
	{
		s_logger.debug("Outputting count " + myMap.get(t) + " for attribute " + t);
		output.put(t,new IntWritable(myMap.get(t)));
	}
			
	context.write(key, output);		
	
}
 
開發者ID:haiqinwang,項目名稱:SmileWide,代碼行數:50,代碼來源:AttributeValueHistogramReducer.java


注:本文中的org.apache.hadoop.io.MapWritable.keySet方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。