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


Java MapWritable.get方法代碼示例

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


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

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
/**
 * Pulls the correct selector from the MapWritable data element given the queryType
 * <p>
 * Pulls first element of array if element is an array type
 */
public static String getSelectorByQueryType(MapWritable dataMap, QuerySchema qSchema, DataSchema dSchema)
{
  String selector;

  String fieldName = qSchema.getSelectorName();
  if (dSchema.isArrayElement(fieldName))
  {
    if (dataMap.get(dSchema.getTextName(fieldName)) instanceof WritableArrayWritable)
    {
      String[] selectorArray = ((WritableArrayWritable) dataMap.get(dSchema.getTextName(fieldName))).toStrings();
      selector = selectorArray[0];
    }
    else
    {
      String[] elementArray = ((ArrayWritable) dataMap.get(dSchema.getTextName(fieldName))).toStrings();
      selector = elementArray[0];
    }
  }
  else
  {
    selector = dataMap.get(dSchema.getTextName(fieldName)).toString();
  }

  return selector;
}
 
開發者ID:apache,項目名稱:incubator-pirk,代碼行數:31,代碼來源:QueryUtils.java

示例3: processTupleViolation

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
private void processTupleViolation(MapWritable fieldMapWritable,
		Map<String, Integer> fieldFileViolationsMap, StringBuffer wb,
		DataViolationWritableBean fileViolationsWritable, String fileName)
		throws IOException {
	IntWritable fieldNumber = new IntWritable();
	IntWritable fieldViolations = new IntWritable(0);
	int violations;
	fieldNumber = new IntWritable(fileViolationsWritable.getFieldNumber());
	fieldViolations = (IntWritable) fieldMapWritable.get((fieldNumber));
	fieldViolations = setFieldViolations(fieldViolations);
	fieldMapWritable.put(fieldNumber, fieldViolations);
	violations = extractViolationsFromMap(fieldFileViolationsMap, fileName);
	violations += 1;
	fieldFileViolationsMap.put(fileName, violations);
	writeViolationsToBuffer(fileViolationsWritable, fileName, wb, violations);
}
 
開發者ID:Impetus,項目名稱:jumbune,代碼行數:17,代碼來源:DataValidationReducer.java

示例4: deserialize

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
@Override
public Object deserialize(final Writable wr) throws SerDeException {
	if (!(wr instanceof MapWritable)) {
		throw new SerDeException("Expected MapWritable, received "
				+ wr.getClass().getName());
	}

	final MapWritable input = (MapWritable) wr;
	final Text t = new Text();
	row.clear();

	for (int i = 0; i < fieldCount; i++) {
		t.set(columnNames.get(i));
		final Writable value = input.get(t);
		if (value != null && !NullWritable.get().equals(value)) {
			row.add(value.toString());
		} else {
			row.add(null);
		}
	}

	return row;
}
 
開發者ID:simonellistonball,項目名稱:hive-azuretables,代碼行數:24,代碼來源:AzureTablesSerDe.java

示例5: 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

示例6: 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

示例7: deserialize

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
@Override
public Object deserialize(Writable wrtbl) throws SerDeException {
    MapWritable input = (MapWritable) wrtbl;
    Text t = new Text();
    row.clear();
    for (int i = 0; i < fieldCount; i++) {
        t.set(majorMinorKeys.get(i));
        Writable value = input.get(t);
        if (value != null && !NullWritable.get().equals(value)) {
            row.add(value.toString());
        } else {
            row.add(null);
        }
    }
    return row;
}
 
開發者ID:vilcek,項目名稱:HiveKVStorageHandler2,代碼行數:17,代碼來源:KVHiveSerDe.java

示例8: map

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
public void map(Text docId, MapWritable doc, OutputCollector<Text, IntWritable> output, Reporter reporter) throws IOException {
	Writable title = doc.get(new Text("text_content"));
	StringTokenizer tokenizer = new StringTokenizer(title.toString());
	while (tokenizer.hasMoreTokens()) {
		word.set(tokenizer.nextToken());
		output.collect(word, one);
	}
	
	/*for (Writable val : doc.values()) {
		word.set(val.toString());
		output.collect(word, one);
	}*/
	
	/*for (Writable key : doc.keySet()) {
		word.set(key.toString());
		output.collect(word, one);
	}*/
	
	/*Writable title = doc.get("article_dc_title");
	if (title != null) {
		log.info(title.toString());
		StringTokenizer tokenizer = new StringTokenizer(title.toString());
		while (tokenizer.hasMoreTokens()) {
			word.set(tokenizer.nextToken());
			output.collect(word, one);
		}
	} else {
		log.info("article_dc_title not found, possible values:");
		for (Writable key : doc.keySet()) {
			log.info("KEY: | " + key.toString() + " |\n");
		}
	}*/
}
 
開發者ID:NLeSC,項目名稱:benchmarking-elasticsearch,代碼行數:34,代碼來源:mapred1.java

示例9: map

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
public void map(Text docId, MapWritable doc, OutputCollector<Text, IntWritable> output, Reporter reporter) throws IOException {
	WritableArrayWritable fields = (WritableArrayWritable) doc.get(new Text("text_content"));
	Writable title = fields.get()[0];
	StringTokenizer tokenizer = new StringTokenizer(title.toString());
	while (tokenizer.hasMoreTokens()) {
		word.set(tokenizer.nextToken());
		output.collect(word, one);
	}
	
	/*for (Writable val : doc.values()) {
		word.set(val.toString());
		output.collect(word, one);
	}*/
	
	/*for (Writable key : doc.keySet()) {
		word.set(key.toString());
		output.collect(word, one);
	}*/
	
	/*Writable title = doc.get("article_dc_title");
	if (title != null) {
		log.info(title.toString());
		StringTokenizer tokenizer = new StringTokenizer(title.toString());
		while (tokenizer.hasMoreTokens()) {
			word.set(tokenizer.nextToken());
			output.collect(word, one);
		}
	} else {
		log.info("article_dc_title not found, possible values:");
		for (Writable key : doc.keySet()) {
			log.info("KEY: | " + key.toString() + " |\n");
		}
	}*/
}
 
開發者ID:NLeSC,項目名稱:benchmarking-elasticsearch,代碼行數:35,代碼來源:mapred2.java

示例10: map

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
public void map(Text docId, MapWritable doc, OutputCollector<Text, IntWritable> output, Reporter reporter) throws IOException {
	WritableArrayWritable fields = (WritableArrayWritable) doc.get(new Text("text_content"));
	Writable content = fields.get()[0];
	StringTokenizer tokenizer = new StringTokenizer(content.toString());
	while (tokenizer.hasMoreTokens()) {
		String word = tokenizer.nextToken();
		if (countMap.containsKey(word)) {
			countMap.put(word, countMap.get(word) + 1);
		} else {
			countMap.put(word, 1);
		}
		//word.set(tokenizer.nextToken());
		//output.collect(word, one);
	}
	
	/*for (Writable val : doc.values()) {
		word.set(val.toString());
		output.collect(word, one);
	}*/
	
	/*for (Writable key : doc.keySet()) {
		word.set(key.toString());
		output.collect(word, one);
	}*/
	
	/*Writable title = doc.get("article_dc_title");
	if (title != null) {
		log.info(title.toString());
		StringTokenizer tokenizer = new StringTokenizer(title.toString());
		while (tokenizer.hasMoreTokens()) {
			word.set(tokenizer.nextToken());
			output.collect(word, one);
		}
	} else {
		log.info("article_dc_title not found, possible values:");
		for (Writable key : doc.keySet()) {
			log.info("KEY: | " + key.toString() + " |\n");
		}
	}*/
}
 
開發者ID:NLeSC,項目名稱:benchmarking-elasticsearch,代碼行數:41,代碼來源:mapred4.java

示例11: map

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
public void map(Text docId, MapWritable doc, OutputCollector<Text, IntWritable> output, Reporter reporter) throws IOException {
	WritableArrayWritable fields = (WritableArrayWritable) doc.get(new Text("text_content"));
	Writable title = fields.get()[0];
	String cleanLine = title.toString().toLowerCase().replaceAll("[_|$#<>\\^=\\[\\]\\*/\\\\,;,.\\-:()?!\"']", " ");
	StringTokenizer tokenizer = new StringTokenizer(cleanLine);
	while (tokenizer.hasMoreTokens()) {
		String w = tokenizer.nextToken();
		if (w.length() < 2) {
			continue;
		}
		word.set(w);
		output.collect(word, one);
	}
	
	/*for (Writable val : doc.values()) {
		word.set(val.toString());
		output.collect(word, one);
	}*/
	
	/*for (Writable key : doc.keySet()) {
		word.set(key.toString());
		output.collect(word, one);
	}*/
	
	/*Writable title = doc.get("article_dc_title");
	if (title != null) {
		log.info(title.toString());
		StringTokenizer tokenizer = new StringTokenizer(title.toString());
		while (tokenizer.hasMoreTokens()) {
			word.set(tokenizer.nextToken());
			output.collect(word, one);
		}
	} else {
		log.info("article_dc_title not found, possible values:");
		for (Writable key : doc.keySet()) {
			log.info("KEY: | " + key.toString() + " |\n");
		}
	}*/
}
 
開發者ID:NLeSC,項目名稱:benchmarking-elasticsearch,代碼行數:40,代碼來源:mapred3.java

示例12: 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

示例13: deserialize

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
@Override
public Object deserialize(Writable wr) throws SerDeException {
    if (!(wr instanceof MapWritable)) {
        throw new SerDeException("Expected MapWritable, received " + wr.getClass().getName());
    }

    final MapWritable input = (MapWritable) wr;
    final Text t = new Text();
    row.clear();

    for (int i = 0; i < fieldCount; i++) {
        t.set(columnNames.get(i));
        final Writable value = input.get(t);
        if (value != null && !NullWritable.get().equals(value)) {
            // parse as double to avoid NumberFormatException...
            // TODO:need more test,especially for type 'bigint'
            if (HIVE_TYPE_INT.equalsIgnoreCase(columnTypesArray.get(i))) {
                row.add(Double.valueOf(value.toString()).intValue());
            } else if (Cql3SerDe.HIVE_TYPE_SMALLINT.equalsIgnoreCase(columnTypesArray.get(i))) {
                row.add(Double.valueOf(value.toString()).shortValue());
            } else if (Cql3SerDe.HIVE_TYPE_TINYINT.equalsIgnoreCase(columnTypesArray.get(i))) {
                row.add(Double.valueOf(value.toString()).byteValue());
            } else if (Cql3SerDe.HIVE_TYPE_BIGINT.equalsIgnoreCase(columnTypesArray.get(i))) {
                row.add(Long.valueOf(value.toString()));
            } else if (Cql3SerDe.HIVE_TYPE_BOOLEAN.equalsIgnoreCase(columnTypesArray.get(i))) {
                row.add(Boolean.valueOf(value.toString()));
            } else if (Cql3SerDe.HIVE_TYPE_FLOAT.equalsIgnoreCase(columnTypesArray.get(i))) {
                row.add(Double.valueOf(value.toString()).floatValue());
            } else if (Cql3SerDe.HIVE_TYPE_DOUBLE.equalsIgnoreCase(columnTypesArray.get(i))) {
                row.add(Double.valueOf(value.toString()));
            } else {
                row.add(value.toString());
            }
        } else {
            row.add(null);
        }
    }

    return row;
}
 
開發者ID:kernel164,項目名稱:hive-cassandra-dsc,代碼行數:41,代碼來源:Cql3SerDe.java

示例14: deserialize

import org.apache.hadoop.io.MapWritable; //導入方法依賴的package包/類
@Override
public Object deserialize(Writable wr) throws SerDeException {

  if (!(wr instanceof MapWritable)) {
    throw new SerDeException("Expected MapWritable, received "
        + wr.getClass().getName());
  }

  final MapWritable input = (MapWritable) wr;
  final Text t = new Text();
  row.clear();

  for (int i = 0; i < fieldCount; i++) {
    t.set(columnNames.get(i));
    final Writable value = input.get(t);
    if (value != null && !NullWritable.get().equals(value)) {
      if (HIVE_TYPE_INT.equalsIgnoreCase(columnTypesArray[i])) {
        row.add(Double.valueOf(value.toString()).intValue());
      }else if (SolrSerDe.HIVE_TYPE_BOOLEAN.equalsIgnoreCase(columnTypesArray[i])) {
        row.add(Boolean.valueOf(value.toString()));
      } else if (SolrSerDe.HIVE_TYPE_FLOAT.equalsIgnoreCase(columnTypesArray[i])) {
        row.add(Double.valueOf(value.toString()).floatValue());
      } else if (SolrSerDe.HIVE_TYPE_DOUBLE.equalsIgnoreCase(columnTypesArray[i])) {
        row.add(Double.valueOf(value.toString()));
      } else {
        row.add(value.toString());
      }

    } else {
      row.add(null);
    }
  }
  return row;
}
 
開發者ID:amitjaspal,項目名稱:solr-storagehandler,代碼行數:35,代碼來源:SolrSerDe.java

示例15: 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


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