TIKA-콘텐츠 추출
Tika는 다양한 파서 라이브러리를 사용하여 주어진 파서에서 콘텐츠를 추출합니다. 주어진 문서 유형을 추출하기위한 올바른 구문 분석기를 선택합니다.
문서를 파싱하기 위해 일반적으로 Tika 파사드 클래스의 parseToString () 메서드가 사용됩니다. 다음은 구문 분석 프로세스와 관련된 단계이며 Tika ParsertoString () 메서드에 의해 추상화됩니다.
파싱 프로세스 추상화-
처음에 Tika에 문서를 전달할 때, Tika와 함께 사용할 수있는 적절한 유형 감지 메커니즘을 사용하고 문서 유형을 감지합니다.
문서 유형이 알려지면 파서 저장소에서 적합한 파서를 선택합니다. 파서 저장소에는 외부 라이브러리를 사용하는 클래스가 포함되어 있습니다.
그런 다음 문서가 전달되어 내용을 구문 분석하고 텍스트를 추출하며 읽을 수없는 형식에 대한 예외도 발생시킬 구문 분석기를 선택합니다.
Tika를 사용한 콘텐츠 추출
다음은 Tika 파사드 클래스를 사용하여 파일에서 텍스트를 추출하는 프로그램입니다.
import java.io.File;
import java.io.IOException;
import org.apache.tika.Tika;
import org.apache.tika.exception.TikaException;
import org.xml.sax.SAXException;
public class TikaExtraction {
public static void main(final String[] args) throws IOException, TikaException {
//Assume sample.txt is in your current directory
File file = new File("sample.txt");
//Instantiating Tika facade class
Tika tika = new Tika();
String filecontent = tika.parseToString(file);
System.out.println("Extracted Content: " + filecontent);
}
}
위의 코드를 TikaExtraction.java로 저장하고 명령 프롬프트에서 실행하십시오.
javac TikaExtraction.java
java TikaExtraction
다음은 sample.txt의 내용입니다.
Hi students welcome to tutorialspoint
다음과 같은 출력을 제공합니다.
Extracted Content: Hi students welcome to tutorialspoint
파서 인터페이스를 사용한 콘텐츠 추출
Tika의 파서 패키지는 텍스트 문서를 파싱 할 수있는 몇 가지 인터페이스와 클래스를 제공합니다. 아래에 주어진 블록 다이어그램은org.apache.tika.parser 꾸러미.
pdf 파서, Mp3Passer, OfficeParser 등 여러 파서 클래스를 사용하여 각 문서를 개별적으로 구문 분석 할 수 있습니다. 이러한 모든 클래스는 파서 인터페이스를 구현합니다.
CompositeParser
주어진 다이어그램은 Tika의 범용 파서 클래스를 보여줍니다. CompositeParser 과 AutoDetectParser. CompositeParser 클래스는 복합 디자인 패턴을 따르므로 파서 인스턴스 그룹을 단일 파서로 사용할 수 있습니다. CompositeParser 클래스는 또한 파서 인터페이스를 구현하는 모든 클래스에 대한 액세스를 허용합니다.
AutoDetectParser
이것은 CompositeParser의 하위 클래스이며 자동 유형 감지를 제공합니다. 이 기능을 사용하여 AutoDetectParser는 복합 방법론을 사용하여 들어오는 문서를 적절한 파서 클래스로 자동으로 보냅니다.
parse () 메서드
parseToString ()과 함께 파서 인터페이스의 parse () 메서드를 사용할 수도 있습니다. 이 메서드의 프로토 타입은 다음과 같습니다.
parse(InputStream stream, ContentHandler handler, Metadata metadata, ParseContext context)
다음 표는 매개 변수로 허용하는 4 개의 오브젝트를 나열합니다.
Sr. 아니. | 개체 및 설명 |
---|---|
1 | InputStream stream 파일의 내용을 포함하는 모든 Inputstream 개체 |
2 | ContentHandler handler Tika는 문서를 XHTML 컨텐츠로이 핸들러에 전달한 후 SAX API를 사용하여 문서를 처리합니다. 문서 내용의 효율적인 후 처리를 제공합니다. |
삼 | Metadata metadata 메타 데이터 개체는 문서 메타 데이터의 소스 및 대상으로 모두 사용됩니다. |
4 | ParseContext context 이 개체는 클라이언트 응용 프로그램이 구문 분석 프로세스를 사용자 지정하려는 경우에 사용됩니다. |
예
다음은 parse () 메서드가 사용되는 방법을 보여주는 예입니다.
Step 1 −
파서 인터페이스의 parse () 메서드를 사용하려면이 인터페이스에 대한 구현을 제공하는 클래스를 인스턴스화하십시오.
PDFParser, OfficeParser, XMLParser 등과 같은 개별 파서 클래스가 있습니다. 이러한 개별 문서 파서를 사용할 수 있습니다. 또는 내부적으로 모든 파서 클래스를 사용하고 적절한 파서를 사용하여 문서의 내용을 추출하는 CompositeParser 또는 AutoDetectParser를 사용할 수 있습니다.
Parser parser = new AutoDetectParser();
(or)
Parser parser = new CompositeParser();
(or)
object of any individual parsers given in Tika Library
Step 2 −
핸들러 클래스 객체를 만듭니다. 다음은 세 가지 컨텐츠 핸들러입니다.
Sr. 아니. | 클래스 및 설명 |
---|---|
1 | BodyContentHandler 이 클래스는 XHTML 출력의 본문 부분을 선택하고 해당 내용을 출력 작성기 또는 출력 스트림에 씁니다. 그런 다음 XHTML 콘텐츠를 다른 콘텐츠 처리기 인스턴스로 리디렉션합니다. |
2 | LinkContentHandler 이 클래스는 XHTML 문서의 모든 H-Ref 태그를 감지 및 선택하고 웹 크롤러와 같은 도구 사용을 위해이를 전달합니다. |
삼 | TeeContentHandler 이 수업은 여러 도구를 동시에 사용하는 데 도움이됩니다. |
우리의 목표는 문서에서 텍스트 내용을 추출하는 것이므로 아래와 같이 BodyContentHandler를 인스턴스화하십시오.
BodyContentHandler handler = new BodyContentHandler( );
Step 3 −
아래와 같이 메타 데이터 개체를 만듭니다.
Metadata metadata = new Metadata();
Step 4 −
입력 스트림 개체를 만들고 추출해야하는 파일을 전달합니다.
FileInputstream
파일 경로를 매개 변수로 전달하여 파일 객체를 인스턴스화하고이 객체를 FileInputStream 클래스 생성자에 전달합니다.
Note − 파일 객체에 전달 된 경로에는 공백이 없어야합니다.
이러한 입력 스트림 클래스의 문제점은 일부 파일 형식을 효율적으로 처리하는 데 필요한 임의 액세스 읽기를 지원하지 않는다는 것입니다. 이 문제를 해결하기 위해 Tika는 TikaInputStream을 제공합니다.
File file = new File(filepath)
FileInputStream inputstream = new FileInputStream(file);
(or)
InputStream stream = TikaInputStream.get(new File(filename));
Step 5 −
아래와 같이 구문 분석 컨텍스트 객체를 만듭니다.
ParseContext context =new ParseContext();
Step 6 −
아래 프로토 타입에 표시된대로 파서 객체를 인스턴스화하고 구문 분석 메서드를 호출하고 필요한 모든 객체를 전달합니다.
parser.parse(inputstream, handler, metadata, context);
다음은 파서 인터페이스를 사용한 콘텐츠 추출 프로그램입니다.
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import org.apache.tika.exception.TikaException;
import org.apache.tika.metadata.Metadata;
import org.apache.tika.parser.AutoDetectParser;
import org.apache.tika.parser.ParseContext;
import org.apache.tika.parser.Parser;
import org.apache.tika.sax.BodyContentHandler;
import org.xml.sax.SAXException;
public class ParserExtraction {
public static void main(final String[] args) throws IOException,SAXException, TikaException {
//Assume sample.txt is in your current directory
File file = new File("sample.txt");
//parse method parameters
Parser parser = new AutoDetectParser();
BodyContentHandler handler = new BodyContentHandler();
Metadata metadata = new Metadata();
FileInputStream inputstream = new FileInputStream(file);
ParseContext context = new ParseContext();
//parsing the file
parser.parse(inputstream, handler, metadata, context);
System.out.println("File content : " + Handler.toString());
}
}
위 코드를 ParserExtraction.java로 저장하고 명령 프롬프트에서 실행하십시오.
javac ParserExtraction.java
java ParserExtraction
아래는 sample.txt의 내용입니다.
Hi students welcome to tutorialspoint
위의 프로그램을 실행하면 다음과 같은 결과가 나옵니다.
File content : Hi students welcome to tutorialspoint