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


Java Hits.doc方法代碼示例

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


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

示例1: addField

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
public boolean addField(String recID, String prefix, String value){
   try {
	   Searcher searcher = new IndexSearcher(indexPath);
	   Query q=new TermQuery(new Term("ID",recID));
	   Hits hits=searcher.search(q);
	   if ((hits==null)||(hits.length()!=1)){
		   return false;
	   }   
	   Document doc=hits.doc(0);
	   IndexWriter iw = getIndexWriter(); 
	   Field f=new Field(prefix,value, Field.Store.YES, Field.Index.UN_TOKENIZED, Field.TermVector.NO);
	   doc.add(f);
	   iw.updateDocument(new Term("ID", recID), doc);
	} catch (IOException ex) {
	   log.fatal(ex);
	   return false;
	 }
	 return true;
}
 
開發者ID:unsftn,項目名稱:bisis-v4,代碼行數:20,代碼來源:BulkIndexer.java

示例2: addField

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
public boolean addField(String recID, String prefix, String value){
  try {
   Searcher searcher = new IndexSearcher(indexPath);
   Query q=new TermQuery(new Term("ID",recID));
   Hits hits=searcher.search(q);
   if ((hits==null)||(hits.length()!=1)){
	   return false;
   }   
   Document doc=hits.doc(0);
   IndexWriter iw = getIndexWriter(); 
   Field f=new Field(prefix,value, Field.Store.YES, Field.Index.UN_TOKENIZED, Field.TermVector.NO);
   doc.add(f);
   iw.updateDocument(new Term("ID", recID), doc);
   iw.close();
} catch (IOException ex) {
   log.fatal(ex);
   return false;
 }
 return true;
}
 
開發者ID:unsftn,項目名稱:bisis-v4,代碼行數:21,代碼來源:Indexer.java

示例3: deleteField

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
public void deleteField(String recID, String prefix, String value){
   try {
	   Searcher searcher = new IndexSearcher(indexPath);
	   Query q=new TermQuery(new Term("ID",recID));
	   Hits hits=searcher.search(q);
	   if ((hits==null)||(hits.length()!=1)){
		   log.fatal("greska pri brisanju polja. Zapis: "+recID);
		   return ;   
	   }   
	   
	   Document doc=hits.doc(0);
	   Field [] fields=doc.getFields(prefix);
	   IndexWriter iw = getIndexWriter(); 
	   doc.removeFields(prefix);
	   for(int i=0;i<fields.length;i++){
		   if(!fields[i].stringValue().equals(value)){
			   doc.add(fields[i]);
		   } 
	   }
	   iw.updateDocument(new Term("ID", recID), doc);
	   iw.close();
	} catch (IOException ex) {
	   log.fatal(ex);
	 }
	 
}
 
開發者ID:unsftn,項目名稱:bisis-v4,代碼行數:27,代碼來源:Indexer.java

示例4: verify

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
private void verify(Directory dir, int expectedHits) throws IOException {
  IndexSearcher searcher = new IndexSearcher(dir);
  Hits hits = searcher.search(new TermQuery(new Term("content", "apache")));
  int numHits = hits.length();

  assertEquals(expectedHits, numHits);

  int[] docs = new int[numHits];
  for (int i = 0; i < numHits; i++) {
    Document hit = hits.doc(i);
    docs[Integer.parseInt(hit.get("id"))]++;
  }
  for (int i = 0; i < numHits; i++) {
    assertEquals(1, docs[i]);
  }

  searcher.close();
}
 
開發者ID:Nextzero,項目名稱:hadoop-2.6.0-cdh5.4.3,代碼行數:19,代碼來源:TestMixedDirectory.java

示例5: debugExplainResults

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
private void debugExplainResults(String indexName, Hits hits, IndexSearcher searcher,
        Query q, Set<Term> queryTerms)
    throws IOException {
    log.debug("Parsed Query is " + q.toString());
    log.debug("Looking at index:  " + indexName);
    for (int i = 0; i < hits.length(); i++) {
        if ((i < 10)) {
            Document doc = hits.doc(i);
            Float score = hits.score(i);
            Explanation ex = searcher.explain(q, hits.id(i));
            log.debug("Looking at hit<" + i + ", " + hits.id(i) + ", " + score +
                    ">: " + doc);
            log.debug("Explanation: " + ex);
            MatchingField match = new MatchingField(q.toString(), doc, queryTerms);
            String fieldName = match.getFieldName();
            String fieldValue = match.getFieldValue();
            log.debug("Guessing that matched fieldName is " + fieldName + " = " +
                    fieldValue);
        }
    }
}
 
開發者ID:spacewalkproject,項目名稱:spacewalk,代碼行數:22,代碼來源:IndexManager.java

示例6: updateDocument

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
public void updateDocument(String documentId, String fieldName,
        String fieldValue) {
    try {
        SearchBean sbean = new SearchBean();
        Hits hresult = sbean.skynetsearch(documentId, "DocumentId");
        Document doc = hresult.doc(0);
        ArrayList<DocumentFields> docfields = new ArrayList<DocumentFields>();
        for (int i = 0; i < fields.length; i++) {
            DocumentFields docFields = new DocumentFields();
            docFields.SetFieldName(fields[i]);
            if (fields[i].equalsIgnoreCase(fieldName)) {
                docFields.SetFieldValue(fieldValue);
            } else {
                docFields.SetFieldValue(doc.get(fields[i]));
            }
            docfields.add(docFields);
        }
        DeleteIndex(documentId);
        CreateIndex(docfields);

    } catch (Exception ex) {
        System.out.print(ex.toString());
    }

}
 
開發者ID:mobilipia,項目名稱:Deskera-HRMS,代碼行數:26,代碼來源:KrawlerIndexCreator.java

示例7: verify

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
private void verify(Shard[] shards) throws IOException {
  // verify the index
  IndexReader[] readers = new IndexReader[shards.length];
  for (int i = 0; i < shards.length; i++) {
    Directory dir =
        new FileSystemDirectory(fs, new Path(shards[i].getDirectory()),
            false, conf);
    readers[i] = IndexReader.open(dir);
  }

  IndexReader reader = new MultiReader(readers);
  IndexSearcher searcher = new IndexSearcher(reader);
  Hits hits = searcher.search(new TermQuery(new Term("content", "apache")));
  assertEquals(0, hits.length());

  hits = searcher.search(new TermQuery(new Term("content", "hadoop")));
  assertEquals(numDocsPerRun / 2, hits.length());

  int[] counts = new int[numDocsPerRun];
  for (int i = 0; i < hits.length(); i++) {
    Document doc = hits.doc(i);
    counts[Integer.parseInt(doc.get("id"))]++;
  }

  for (int i = 0; i < numDocsPerRun; i++) {
    if (i % 2 == 0) {
      assertEquals(0, counts[i]);
    } else {
      assertEquals(1, counts[i]);
    }
  }

  searcher.close();
  reader.close();
}
 
開發者ID:Nextzero,項目名稱:hadoop-2.6.0-cdh5.4.3,代碼行數:36,代碼來源:TestDistributionPolicy.java

示例8: searchCorpus

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
/**
 * Searches the current corpus using the search terms in the search field.
 */
private void searchCorpus() {
    if (search.getText().trim().equals("")) return;
    try {
        indexSearcher = guess.getSelected() != null ?
            getIndex(getDiffCorpus(gold.getSelected(), guess.getSelected())) :
            getIndex(gold.getSelected());
        //System.out.println("Searching...");
        QueryParser parser = new QueryParser("Word", analyzer);
        Query query = parser.parse(search.getText());
        Hits hits = indexSearcher.search(query);
        Highlighter highlighter = new Highlighter(new QueryScorer(query));
        DefaultListModel model = new DefaultListModel();
        for (int i = 0; i < hits.length(); i++) {
            Document hitDoc = hits.doc(i);
            int nr = Integer.parseInt(hitDoc.get("<nr>"));
            //System.out.println(hitDoc.get("<nr>"));
            String best = null;
            for (Object field : hitDoc.getFields()) {
                Field f = (Field) field;
                best = highlighter.getBestFragment(analyzer, f.name(), hitDoc.get(f.name()));
                if (best != null) break;
            }
            if (best != null)
                model.addElement(new Result(nr, "<html>" + nr + ":" + best + "</html>"));
            //System.out.println(highlighter.getBestFragment(analyzer, "Word", hitDoc.get("Word")));
            //assertEquals("This is the text to be indexed.", hitDoc.get("fieldname"));
        }
        results.setModel(model);
        repaint();
    } catch (Exception ex) {
        ex.printStackTrace();
    }
}
 
開發者ID:riedelcastro,項目名稱:whatswrong,代碼行數:37,代碼來源:CorpusNavigator.java

示例9: iterate

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
/**
 * Iterates search result
 * @param hits a ranked list of found documents
 */
void iterate(Hits hits) {
    for (int i = 0; i < hits.length(); i++) {
        try {
            result = hits.doc(i);
            if (LOG.isLoggable(Level.FINE)) {
                LOG.fine("Processing search result: " + result);
            }
            queryCallback.processRow(this); //notifying a callback
        } catch (IOException e) {
            throw new LuceneProviderException("Failed to get query result.",e);
        }
    }
}
 
開發者ID:scriptella,項目名稱:scriptella-etl,代碼行數:18,代碼來源:LuceneQuery.java

示例10: displayHits

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
protected void displayHits(Hits hits) throws IOException {
    for (int i = 0; i < hits.length(); i++) {
        Document doc = hits.doc(i);
        String name = doc.get("name");
        String description = doc.get("description");
        log.info("Hit<" + i + "> Score< " + hits.score(i) + ">  name = <" +
                name + "> description = <" + description + ">");
    }
}
 
開發者ID:spacewalkproject,項目名稱:spacewalk,代碼行數:10,代碼來源:NGramTestSetup.java

示例11: getPaths

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
private Set<List<String>> getPaths(Hits hits) throws IOException
{
	Set<List<String>> paths = new HashSet<List<String>>();
	
	for (int i = 0; i < hits.length(); i++)
	{
    	Document doc = hits.doc(i);
	    String srcConcept = 
	    	doc.get(KnowledgeBasePathIndexField.START.toString());
	    String targetConcept = 
	    	doc.get(KnowledgeBasePathIndexField.END.toString());
	    String pathsString = 
	    	doc.get(KnowledgeBasePathIndexField.PATHS.toString());

	    if (!pathsString.isEmpty())
	    {
		    for (String pathString : pathsString.split(QUOTED_PATH_SEPARATOR))
		    {
		    	List<String> path = new ArrayList<String>();

		    	path.add(srcConcept);
		    	for (String pathElement : pathString.split(" "))
		    		path.add(pathElement);
		    	path.add(targetConcept);
		    	
		    	// sanity check
		    	if ((path.size() % 3) != 1) log.warn("INVALID PATH: " + path);
		    	else paths.add(path);
		    }
	    }
	}
    return paths;
}
 
開發者ID:iucl,項目名稱:l2-writing-assistant,代碼行數:34,代碼來源:KnowledgeBasePathIndex.java

示例12: main

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
public static void main(String[] args) {
   try {
     Searcher searcher = new IndexSearcher("index");
     Analyzer analyzer = new StandardAnalyzer();

     BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
     while (true) {
System.out.print("Query: ");
String line = in.readLine();

if (line.length() == -1)
  break;

Query query = QueryParser.parse(line, "contents", analyzer);
System.out.println("Searching for: " + query.toString("contents"));

Hits hits = searcher.search(query);
System.out.println(hits.length() + " total matching documents");

final int HITS_PER_PAGE = 10;
for (int start = 0; start < hits.length(); start += HITS_PER_PAGE) {
  int end = Math.min(hits.length(), start + HITS_PER_PAGE);
  for (int i = start; i < end; i++) {
    Document doc = hits.doc(i);
    String path = doc.get("path");
    if (path != null) {
             System.out.println(i + ". " + path);
    } else {
             String url = doc.get("url");
      if (url != null) {
	System.out.println(i + ". " + url);
	System.out.println("   - " + doc.get("title"));
      } else {
	System.out.println(i + ". " + "No path nor URL for this document");
      }
    }
  }

  if (hits.length() > end) {
    System.out.print("more (y/n) ? ");
    line = in.readLine();
    if (line.length() == 0 || line.charAt(0) == 'n')
      break;
  }
}
     }
     searcher.close();

   } catch (Exception e) {
     System.out.println(" caught a " + e.getClass() +
		 "\n with message: " + e.getMessage());
   }
 }
 
開發者ID:parabuild-ci,項目名稱:parabuild-ci,代碼行數:54,代碼來源:SearchFiles.java

示例13: test_process

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
/**
 * Test
 */
public final void test_process() throws Exception {
  // init current number of log files
  final StepRun stepRun = cm.getStepRun(stepResultID());
  final List logsBefore = cm.getAllStepLogs(stepRun.getID());
  final int logCountBefore = logsBefore.size();
  final int logCountExistsBefore = getExistsCount(logsBefore);

  // call implementor's process logs method
  if (log.isDebugEnabled()) log.debug("first run");
  processLogs();

  // get counters after processing
  final List logsAfter = cm.getAllStepLogs(stepRun.getID());
  final int logCountAfter = logsAfter.size();
  final int logCountExistsAfter = getExistsCount(logsAfter);

  // check if logs in the db
  if (log.isDebugEnabled()) log.debug("logCountBefore = " + logCountBefore);
  if (log.isDebugEnabled()) log.debug("logCountAfter = " + logCountAfter);
  assertTrue("Number of logs after should be bigger then before", logCountAfter > logCountBefore);
  assertEquals(1, logCountAfter - logCountBefore);

  // check if logs are accesible from archive
  assertEquals(logCountExistsAfter - logCountExistsBefore, logCountAfter - logCountBefore);

  // run second time to make sure same results are not picked twice.
  if (log.isDebugEnabled()) log.debug("second run");
  processLogs();
  assertEquals("Number of logs should not change after second run", logCountAfter, cm.getAllStepLogs(stepRun.getID()).size());
  assertEquals("Number of archived logs should not change after second run", logCountExistsAfter, getExistsCount(cm.getAllStepLogs(stepRun.getID())));

  // check if logs got indexed/searchable where applicable
  if (!StringUtils.isBlank(stringToBeFoundBySearch())) {
    if (log.isDebugEnabled()) log.debug("Check if can find in log: " + stringToBeFoundBySearch());
    Hits results = searchManager.search(new SearchRequest(stringToBeFoundBySearch()));
    if (results.length() == 0) {
      // let indexer queue to process logs
      Thread.sleep(500);
      // retry search
      results = searchManager.search(new SearchRequest(stringToBeFoundBySearch()));
    }
    assertTrue(results.length() > 0);
    // check if required fields are there
    for (int i = 0; i < results.length(); i++) {
      final Document result = results.doc(i);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_BUILD_ID);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_BUILD_NAME);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_BUILD_RUN_NUMBER);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_BUILD_RUN_ID);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_BUILD_STARTED);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_DOCUMENT_TYPE);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_SEQUENCE_LOG_ID);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_SEQUENCE_LOG_DESCR);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_SEQUENCE_LOG_CONFIG_PATH);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_SEQUENCE_LOG_PATH_TYPE);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_SEQUENCE_LOG_TYPE);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_SEQUENCE_NAME);
    }
  }
}
 
開發者ID:parabuild-ci,項目名稱:parabuild-ci,代碼行數:64,代碼來源:AbstractCustomLogTest.java

示例14: testProcess

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
/**
 * Test
 */
public final void testProcess() throws Exception {
  // init current number of result files
  final StepRun stepRun = cm.getStepRun(stepRunID());
  final List resultsBefore = cm.getAllStepResults(stepRun);
  final int resultCountBefore = resultsBefore.size();
  final int resultCountExistsBefore = getExistsCount(resultsBefore);

  // call implementor's process results method
  if (LOG.isDebugEnabled()) {
    LOG.debug("first run");
  }
  processResults();

  // get counters after processing
  final List resultsAfter = cm.getAllStepResults(stepRun);
  final int resultCountAfter = resultsAfter.size();
  final int resultCountExistsAfter = getExistsCount(resultsAfter);

  // check if results in the db
  if (LOG.isDebugEnabled()) {
    LOG.debug("resultCountBefore = " + resultCountBefore);
  }
  if (LOG.isDebugEnabled()) {
    LOG.debug("resultCountAfter = " + resultCountAfter);
  }

  assertTrue("Number of results after should be bigger then before", resultCountAfter > resultCountBefore);
  assertTrue("Number of results should increase", resultCountAfter - resultCountBefore >= 1);
  assertEquals("Number of results accessible from archive should be the same as in the database", resultCountExistsAfter - resultCountExistsBefore, resultCountAfter - resultCountBefore);

  // run second time to make sure same results are not picked twice.
  if (LOG.isDebugEnabled()) {
    LOG.debug("second run");
  }
  processResults();
  assertEquals("Number of results should not change after second run", resultCountAfter, cm.getAllStepResults(stepRun).size());
  assertEquals("Number of archived results should not change after second run", resultCountExistsAfter, getExistsCount(resultsAfter));

  // check if results got indexed/searchable where applicable
  if (!StringUtils.isBlank(stringToBeFoundBySearch())) {
    if (LOG.isDebugEnabled()) {
      LOG.debug("Check if can find in result: " + stringToBeFoundBySearch());
    }
    Hits results = searchManager.search(new SearchRequest(stringToBeFoundBySearch()));
    if (results.length() == 0) {
      // let indexer queue to process results
      Thread.sleep(500);
      // retry search
      results = searchManager.search(new SearchRequest(stringToBeFoundBySearch()));
    }
    assertTrue(results.length() > 0);
    // check if required fields are there
    for (int i = 0; i < results.length(); i++) {
      final Document result = results.doc(i);
      // header
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_BUILD_ID);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_BUILD_NAME);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_BUILD_RUN_NUMBER);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_BUILD_RUN_ID);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_BUILD_STARTED);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_DOCUMENT_TYPE);
      // result specific
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_RESULT_FILE_NAME);
      assertFieldPresent(result, LuceneDocumentFactory.FIELD_RESULT_STEP_RESULT_ID);
    }
  }
}
 
開發者ID:parabuild-ci,項目名稱:parabuild-ci,代碼行數:71,代碼來源:AbstractResultHandlerTest.java

示例15: search

import org.apache.lucene.search.Hits; //導入方法依賴的package包/類
/**
	 * Execute search using index.
	 * 
	 * @param indexPath
	 *            the index path
	 * @param queryString
	 *            the query string
	 * @return Returns an array of <code>SearchResultEntry</code> otherwise
	 *         null.
	 */
	public SearchResultEntry[] search(String queryString) {
		ArrayList<SearchResultEntry> result = new ArrayList<SearchResultEntry>();

		try {
			Searcher searcher = new IndexSearcher(indexPath);
			Analyzer analyzer = new StandardAnalyzer();

			String line = queryString;

			logger.debug("Query: " + line);
            QueryParser queryParser=new QueryParser("contents", analyzer);
            Query query = queryParser.parse(line);
            
			logger.debug("\nSearching for: '" + query.toString("contents")
					+ "'");
			Hits hits = searcher.search(query);
			logger.debug("Search result: " + hits.length()
					+ " total matching documents");

			for (int i = 0; i < hits.length(); i++) {
				Document doc = hits.doc(i);
				String path = doc.get("path");

				if (path != null) {
					logger.debug(i + ". " + path);
					// i'm interested only in concepts so filter out
					// non-concepts (HACK)
					// TODO this filter is here because of obsolete indexes -
					// there should be deleted
					if (path.indexOf(File.separator + "concepts"
							+ File.separator) >= 0) {
						result.add(new SearchResultEntry(doc
								.get("outlineLabel"), doc.get("conceptLabel"),
								doc.get("path")));
//						 logger.debug("path:\n"+doc.get("path"));
//						 logger.debug("modified:\n"+doc.get("modified"));
//						 logger.debug("notebook:\n"+doc.get("outlineLabel"));
//						 logger.debug("concept:\n"+doc.get("conceptLabel"));
					}

				} else {
					String url = doc.get("url");
					if (url != null) {
						logger.debug(i + ". " + url);
						logger.debug("   - " + doc.get("title"));
					} else {
						logger.debug(i + ". "
								+ "No path nor URL for this document");
					}
				}
			}
			searcher.close();

			return (SearchResultEntry[]) result
					.toArray(new SearchResultEntry[result.size()]);
		} catch (Exception e) {
			logger.error("Caught a " + e.getClass() + "\n with message: "
					+ e.getMessage(), e);
		}
		return null;
	}
 
開發者ID:dvorka,項目名稱:mindraider,代碼行數:72,代碼來源:SearchEngine.java


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