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


Java BodyContentHandler.toString方法代碼示例

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


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

示例1: readXlsx

import org.apache.tika.sax.BodyContentHandler; //導入方法依賴的package包/類
public static ExcelData readXlsx(String xlsxFilePath)
    throws IOException, InvalidFormatException, XmlException, TikaException, SAXException {
  BodyContentHandler bcHandler = new BodyContentHandler();
  Metadata metadata = new Metadata();
  FileInputStream inputStream = new FileInputStream(new File(xlsxFilePath));
  ParseContext pcontext = new ParseContext();
  OOXMLParser parser = new OOXMLParser();
  parser.parse(inputStream, bcHandler, metadata, pcontext);
  if (DEBUG_PRINT_META_DATA) {
    System.err.println("Metadata:");
    for (String name : metadata.names())
      System.out.println(name + "\t:\t" + metadata.get(name));
  }
  ExcelData spreedsheet = new ExcelData(bcHandler.toString());
  return spreedsheet;
}
 
開發者ID:mark-watson,項目名稱:power-java,代碼行數:17,代碼來源:PoiMicrosoftFileReader.java

示例2: parse

import org.apache.tika.sax.BodyContentHandler; //導入方法依賴的package包/類
public ParsedData parse(InputStream stream, String fileName, String contentType) {
    BodyContentHandler handler = new BodyContentHandler(MAX_CHARACTERS);
    BoilerpipeContentHandler textHandler = new BoilerpipeContentHandler(handler, KeepEverythingExtractor.INSTANCE);
    Metadata metadata = createMetadata(fileName, contentType);
    ParseContext context = new ParseContext();
    try {
        parser.parse(stream, textHandler, metadata, context);
        
        Map<String, String> metadataMap = new HashMap<String, String>();
        for (String propertyName : metadata.names()) {
            metadataMap.put(propertyName, metadata.get(propertyName));
        }
        
        return new ParsedData(handler.toString(), metadataMap);
        
    } catch (IOException | SAXException | TikaException e) {
        logger.error("Failed to extract metadata using Tika.", e);
        return null;
    }
}
 
開發者ID:ViDA-NYU,項目名稱:ache,代碼行數:21,代碼來源:TikaExtractor.java

示例3: fromFile

import org.apache.tika.sax.BodyContentHandler; //導入方法依賴的package包/類
@Override
public String fromFile(File file) {
	String resultText = "";

	try {
		FileInputStream inputstream = new FileInputStream(file);
		BodyContentHandler handler = new BodyContentHandler(-1);
		Metadata metadata = new Metadata();
		ParseContext pcontext = new ParseContext();

		PDFParserConfig config = new PDFParserConfig();
		config.setSortByPosition(true);

		PDFParser pdfparser = new PDFParser();
		pdfparser.setPDFParserConfig(config);
		
		System.out.println("Parsing PDF to TEXT...");
		
		pdfparser.parse(inputstream, handler, metadata, pcontext);
		resultText = handler.toString();
		
		System.out.println("Parsing complete");
	} catch (Exception ex) {
		throw new RuntimeException(ex);
	}

	return resultText;
}
 
開發者ID:eduardohmg,項目名稱:diario-extractor,代碼行數:29,代碼來源:PDFToTextImpl.java

示例4: extract

import org.apache.tika.sax.BodyContentHandler; //導入方法依賴的package包/類
public String extract(String path) throws Exception {
    BodyContentHandler handler = new BodyContentHandler(Integer.MAX_VALUE);
    try (FileInputStream stream = new FileInputStream(path)) {
        Metadata metadata = new Metadata();
        parser.parse(stream, handler, metadata, parseContext);
        //System.out.println(metadata);
        return handler.toString();
    }
}
 
開發者ID:thammegowda,項目名稱:pdf-extractor,代碼行數:10,代碼來源:PDFExtract.java

示例5: parsePdfFileToPlainText

import org.apache.tika.sax.BodyContentHandler; //導入方法依賴的package包/類
/**
 * 將PDF文件解析為文本
 * @param file 本地PDF文件的相對路徑或絕對路徑
 * @return 提取的文本
 */
public static String parsePdfFileToPlainText(String file) {
    try(InputStream stream = new FileInputStream(file)) {
        BodyContentHandler handler = new BodyContentHandler(Integer.MAX_VALUE);
        Metadata metadata = new Metadata();
        PARSER.parse(stream, handler, metadata);
        return handler.toString();
    } catch (Exception e){
        e.printStackTrace();
    }
    return "";
}
 
開發者ID:ysc,項目名稱:superword,代碼行數:17,代碼來源:PdfParser.java

示例6: doProcessStream

import org.apache.tika.sax.BodyContentHandler; //導入方法依賴的package包/類
@Override
public void doProcessStream(InputStream stream, String source, JCas jCas) throws IOException {
	super.doProcessStream(stream, source, jCas);

	try {
		BodyContentHandler textHandler = new BodyContentHandler(Integer.MAX_VALUE);
		Metadata metadata = new Metadata();
		ParseContext context = new ParseContext();

		AutoDetectParser autoParser = new AutoDetectParser();
		autoParser.parse(stream, textHandler, metadata, context);

		String fullContent = textHandler.toString();
		Matcher m = tearlinePattern.matcher(fullContent);
		if(m.find()){
			jCas.setDocumentText(removeBoilerplate(fullContent.substring(0, m.start())).trim());
		}else{
			jCas.setDocumentText(removeBoilerplate(fullContent).trim());
		}

		for (String name : metadata.names()) {
			addMetadata(jCas, name, metadata.get(name));
		}
	} catch (SAXException | TikaException e) {
		getMonitor().warn("Couldn't parse metadata from '{}'", source, e);
	}
}
 
開發者ID:dstl,項目名稱:baleen,代碼行數:28,代碼來源:TearlineContentExtractor.java

示例7: parseToPlainText

import org.apache.tika.sax.BodyContentHandler; //導入方法依賴的package包/類
public static String parseToPlainText(InputStream fileStream) {
    BodyContentHandler handler = new BodyContentHandler();
    AutoDetectParser parser = new AutoDetectParser();
    Metadata metadata = new Metadata();
    String rawContent = "";

    try {
        parser.parse(fileStream, handler, metadata);
        rawContent = handler.toString();
    } catch (IOException | SAXException | TikaException e) {
        LOG.debug("Parsing Exception while extracting content from current file. "
                + e.toString());
    }
    return rawContent;
}
 
開發者ID:ziqizhang,項目名稱:jate,代碼行數:16,代碼來源:JATEUtil.java

示例8: htmlParserShouldReturnIndentedSentenceWithTwoLineBreaks

import org.apache.tika.sax.BodyContentHandler; //導入方法依賴的package包/類
@Test
public void htmlParserShouldReturnIndentedSentenceWithTwoLineBreaks() throws Exception {
    final String html = "<html><head><title>Title</title></head>" +
            "<body><ul><li>one</li></ul></body></html>";

    BodyContentHandler handler = new BodyContentHandler();
    new HtmlParser().parse(
            new ByteArrayInputStream(html.getBytes("UTF-8")),
            handler,  new Metadata(), new ParseContext());

    // Make sure we get <tab>, "one", newline, newline
    String result = handler.toString();

    assertTrue(Pattern.matches("\tone\n\n", result));
}
 
開發者ID:kanrourou,項目名稱:software-testing,代碼行數:16,代碼來源:HtmlParserBDDTest3.java

示例9: conversionImplementation

import org.apache.tika.sax.BodyContentHandler; //導入方法依賴的package包/類
/**
 * Common implementation -- take an input stream and return a ConvertedDoc;
 *
 * @param input stream for raw file
 * @param doc raw file
 * @return converted doc
 * @throws IOException if underlying Tika parser/writer had an IO problem, an parser
 *             problem, or MAX_TEXT_SIZE is reached.
 */
@Override
protected ConvertedDocument conversionImplementation(InputStream input, java.io.File doc)
        throws IOException {
    Metadata metadata = new Metadata();
    BodyContentHandler handler = new BodyContentHandler(maxBuffer);

    try {
        parser.parse(input, handler, metadata, ctx);
    } catch (NoClassDefFoundError classErr){
        throw new IOException("Unable to parse content due to Tika misconfiguration", classErr);
    } catch (Exception xerr) {
        throw new IOException("Unable to parse content", xerr);
    } finally {
        input.close();
    }
    ConvertedDocument textdoc = new ConvertedDocument(doc);

    textdoc.addTitle(metadata.get(TikaCoreProperties.TITLE));
    textdoc.setEncoding(metadata.get(Metadata.CONTENT_ENCODING));
    textdoc.addCreateDate(metadata.getDate(TikaCoreProperties.CREATED));
    textdoc.addAuthor(metadata.get(TikaCoreProperties.CREATOR));

    // v1.5:  until this version this blank line reducer was in place.
    //     Using Java6 it appeared to cause StackOverflow when it encountered a document hundreds of \n in a row.
    //     Eg.., a Spreadsheet doc converted to text may have thousands of empty lines following the last data row.
    // TextUtils.reduce_line_breaks(txt)
    String t = handler.toString();
    if (t != null) {
        if (textdoc.filename!= null && FileUtility.isSpreadsheet(textdoc.filename)) {
            textdoc.setText(t.trim());
        } else {
            textdoc.setText(TextUtils.reduce_line_breaks(t));
        }
    }
    return textdoc;
}
 
開發者ID:OpenSextant,項目名稱:Xponents,代碼行數:46,代碼來源:DefaultConverter.java

示例10: discoverAgainstSingleModel

import org.apache.tika.sax.BodyContentHandler; //導入方法依賴的package包/類
private List<FileMatchMetaData> discoverAgainstSingleModel(final Properties fileDiscoveryProperties, final Model model, final double probabilityThreshold)
throws AnonymizerException, IOException, SAXException, TikaException {
    // Start running NLP algorithms for each column and collect percentage
    fileMatches = new ArrayList<>();
    String[] directoryList = null;
    String[] exclusionList = null;
    final String directories = fileDiscoveryProperties.getProperty("directories");
    final String exclusions = fileDiscoveryProperties.getProperty("exclusions");
    directoryList = directories.split(",");
    exclusionList = exclusions.split(",");

    // Let's iterate over directories
    File node;
    Metadata metadata;
    List<Probability> probabilityList;
    log.info("File types not considered for analysis: " + exclusions);

    for (final String directory: directoryList) {

        node = new File(directory);
        final List<File> files = (List<File>) FileUtils.listFiles(node, null, true);

        for (final File fich : files) {
                final String file = fich.getName().toString();
                final String recursivedir = fich.getParent().toString();

                log.info("Analyzing [" + fich.getCanonicalPath() + "]");

                final String ext = CommonUtils.getFileExtension(fich);

                  if (Arrays.asList(exclusionList).contains(ext)) {
                    // less verbose - Ignored types on the top
                      continue;
                  }

                final BodyContentHandler handler = new BodyContentHandler(-1);

                final AutoDetectParser parser = new AutoDetectParser();
                metadata = new Metadata();
                String handlerString = "";
                try  {
                final InputStream stream = new FileInputStream(fich.getCanonicalPath());
                    if (stream != null) {
                        parser.parse(stream, handler, metadata);
                        handlerString =  handler.toString();
                    }
                }
                catch (IOException e) {
                  log.info("Unable to read " + fich.getCanonicalPath() +".Ignoring...");
                  }


                log.debug("Content: " + handlerString);
                final String tokens[] = model.getTokenizer().tokenize(handler.toString());
                final Span nameSpans[] = model.getNameFinder().find(tokens);
                final double[] spanProbs = model.getNameFinder().probs(nameSpans);
                //display names
                probabilityList = new ArrayList<>();
                for( int i = 0; i < nameSpans.length; i++) {
                    log.info("Span: "+nameSpans[i].toString());
                    log.info("Covered text is: "+tokens[nameSpans[i].getStart()]);
                    log.info("Probability is: "+spanProbs[i]);
                    probabilityList.add(new Probability(tokens[nameSpans[i].getStart()], spanProbs[i]));
                }
                model.getNameFinder().clearAdaptiveData();

                final double averageProbability = calculateAverage(probabilityList);
                if ((averageProbability >= probabilityThreshold)) {
                    final FileMatchMetaData result = new FileMatchMetaData(recursivedir, file);
                    result.setAverageProbability(averageProbability);
                    result.setModel(model.getName());
                    fileMatches.add(result);
                }
            }
        }


    return fileMatches;
  }
 
開發者ID:armenak,項目名稱:DataDefender,代碼行數:80,代碼來源:FileDiscoverer.java


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