OpenNLP-토큰 화
주어진 문장을 작은 부분 (토큰)으로 자르는 과정은 다음과 같이 알려져 있습니다. tokenization. 일반적으로 주어진 원시 텍스트는 구분 기호 집합 (주로 공백)을 기반으로 토큰 화됩니다.
토큰 화는 맞춤법 검사, 검색 처리, 품사 식별, 문장 감지, 문서 문서 분류 등과 같은 작업에 사용됩니다.
OpenNLP를 사용한 토큰 화
그만큼 opennlp.tools.tokenize 패키지에는 토큰 화를 수행하는 데 사용되는 클래스와 인터페이스가 포함되어 있습니다.
주어진 문장을 더 간단한 조각으로 토큰 화하기 위해 OpenNLP 라이브러리는 세 가지 다른 클래스를 제공합니다.
SimpleTokenizer −이 클래스는 문자 클래스를 사용하여 주어진 원시 텍스트를 토큰 화합니다.
WhitespaceTokenizer −이 클래스는 주어진 텍스트를 토큰 화하기 위해 공백을 사용합니다.
TokenizerME−이 클래스는 원시 텍스트를 별도의 토큰으로 변환합니다. 최대 엔트로피를 사용하여 결정을 내립니다.
SimpleTokenizer
다음을 사용하여 문장을 토큰 화하려면 SimpleTokenizer 수업, 당신은-
각 클래스의 개체를 만듭니다.
다음을 사용하여 문장을 토큰 화하십시오. tokenize() 방법.
토큰을 인쇄하십시오.
다음은 주어진 원시 텍스트를 토큰 화하는 프로그램을 작성하기 위해 따라야 할 단계입니다.
Step 1 − 각 클래스 인스턴스화
두 클래스 모두 인스턴스화하는 데 사용할 수있는 생성자가 없습니다. 따라서 정적 변수를 사용하여 이러한 클래스의 객체를 생성해야합니다.INSTANCE.
SimpleTokenizer tokenizer = SimpleTokenizer.INSTANCE;
Step 2 − 문장 토큰 화
이 두 클래스 모두 tokenize(). 이 메서드는 문자열 형식의 원시 텍스트를받습니다. 호출시 주어진 문자열을 토큰 화하고 문자열 (토큰) 배열을 반환합니다.
다음을 사용하여 문장을 토큰 화하십시오. tokenizer() 방법은 아래와 같습니다.
//Tokenizing the given sentence
String tokens[] = tokenizer.tokenize(sentence);
Step 3 − 토큰 인쇄
문장을 토큰 화 한 후 다음을 사용하여 토큰을 인쇄 할 수 있습니다. for loop, 아래 그림과 같이.
//Printing the tokens
for(String token : tokens)
System.out.println(token);
Example
다음은 SimpleTokenizer 클래스를 사용하여 주어진 문장을 토큰 화하는 프로그램입니다. 이 프로그램을 이름의 파일에 저장하십시오.SimpleTokenizerExample.java.
import opennlp.tools.tokenize.SimpleTokenizer;
public class SimpleTokenizerExample {
public static void main(String args[]){
String sentence = "Hi. How are you? Welcome to Tutorialspoint. "
+ "We provide free tutorials on various technologies";
//Instantiating SimpleTokenizer class
SimpleTokenizer simpleTokenizer = SimpleTokenizer.INSTANCE;
//Tokenizing the given sentence
String tokens[] = simpleTokenizer.tokenize(sentence);
//Printing the tokens
for(String token : tokens) {
System.out.println(token);
}
}
}
다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.
javac SimpleTokenizerExample.java
java SimpleTokenizerExample
실행시 위의 프로그램은 주어진 문자열 (원시 텍스트)을 읽고 토큰 화하고 다음 출력을 표시합니다.
Hi
.
How
are
you
?
Welcome
to
Tutorialspoint
.
We
provide
free
tutorials
on
various
technologies
WhitespaceTokenizer
다음을 사용하여 문장을 토큰 화하려면 WhitespaceTokenizer 수업, 당신은-
각 클래스의 개체를 만듭니다.
다음을 사용하여 문장을 토큰 화하십시오. tokenize() 방법.
토큰을 인쇄하십시오.
다음은 주어진 원시 텍스트를 토큰 화하는 프로그램을 작성하기 위해 따라야 할 단계입니다.
Step 1 − 각 클래스 인스턴스화
두 클래스 모두 인스턴스화하는 데 사용할 수있는 생성자가 없습니다. 따라서 정적 변수를 사용하여 이러한 클래스의 객체를 생성해야합니다.INSTANCE.
WhitespaceTokenizer tokenizer = WhitespaceTokenizer.INSTANCE;
Step 2 − 문장 토큰 화
이 두 클래스 모두 tokenize(). 이 메서드는 문자열 형식의 원시 텍스트를받습니다. 호출시 주어진 문자열을 토큰 화하고 문자열 (토큰) 배열을 반환합니다.
다음을 사용하여 문장을 토큰 화하십시오. tokenizer() 방법은 아래와 같습니다.
//Tokenizing the given sentence
String tokens[] = tokenizer.tokenize(sentence);
Step 3 − 토큰 인쇄
문장을 토큰 화 한 후 다음을 사용하여 토큰을 인쇄 할 수 있습니다. for loop, 아래 그림과 같이.
//Printing the tokens
for(String token : tokens)
System.out.println(token);
Example
다음은 주어진 문장을 토큰 화하는 프로그램입니다. WhitespaceTokenizer수업. 이 프로그램을 이름의 파일에 저장하십시오.WhitespaceTokenizerExample.java.
import opennlp.tools.tokenize.WhitespaceTokenizer;
public class WhitespaceTokenizerExample {
public static void main(String args[]){
String sentence = "Hi. How are you? Welcome to Tutorialspoint. "
+ "We provide free tutorials on various technologies";
//Instantiating whitespaceTokenizer class
WhitespaceTokenizer whitespaceTokenizer = WhitespaceTokenizer.INSTANCE;
//Tokenizing the given paragraph
String tokens[] = whitespaceTokenizer.tokenize(sentence);
//Printing the tokens
for(String token : tokens)
System.out.println(token);
}
}
다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.
javac WhitespaceTokenizerExample.java
java WhitespaceTokenizerExample
실행시 위 프로그램은 주어진 문자열 (원시 텍스트)을 읽고이를 토큰 화하고 다음 출력을 표시합니다.
Hi.
How
are
you?
Welcome
to
Tutorialspoint.
We
provide
free
tutorials
on
various
technologies
TokenizerME 클래스
OpenNLP는 또한 사전 정의 된 모델 인 de-token.bin이라는 파일을 사용하여 문장을 토큰 화합니다. 주어진 원시 텍스트의 문장을 토큰 화하도록 훈련되었습니다.
그만큼 TokenizerME 의 클래스 opennlp.tools.tokenizer패키지는이 모델을로드하는 데 사용되며 OpenNLP 라이브러리를 사용하여 주어진 원시 텍스트를 토큰 화합니다. 그렇게하려면 다음을 수행해야합니다.
로드 en-token.bin 모델을 사용하여 TokenizerModel 수업.
인스턴스화 TokenizerME 수업.
다음을 사용하여 문장을 토큰 화하십시오. tokenize() 이 클래스의 메서드.
다음은 주어진 원시 텍스트에서 문장을 토큰 화하는 프로그램을 작성하기 위해 따라야 할 단계입니다. TokenizerME 수업.
Step 1 − 모델로드
토큰 화 모델은 다음과 같은 클래스로 표현됩니다. TokenizerModel, 패키지에 속하는 opennlp.tools.tokenize.
토크 나이저 모델을로드하려면-
만들기 InputStream 모델의 객체 (FileInputStream을 인스턴스화하고 모델의 경로를 String 형식으로 생성자에 전달).
인스턴스화 TokenizerModel 수업과 통과 InputStream 다음 코드 블록과 같이 생성자에 대한 매개 변수로 모델의 (객체).
//Loading the Tokenizer model
InputStream inputStream = new FileInputStream("C:/OpenNLP_models/en-token.bin");
TokenizerModel tokenModel = new TokenizerModel(inputStream);
Step 2 − TokenizerME 클래스 인스턴스화
그만큼 TokenizerME 패키지 클래스 opennlp.tools.tokenize원시 텍스트를 작은 부분 (토큰)으로 자르는 방법이 포함되어 있습니다. 최대 엔트로피를 사용하여 결정을 내립니다.
이 클래스를 인스턴스화하고 아래와 같이 이전 단계에서 만든 모델 개체를 전달합니다.
//Instantiating the TokenizerME class
TokenizerME tokenizer = new TokenizerME(tokenModel);
Step 3 − 문장 토큰 화
그만큼 tokenize() 의 방법 TokenizerME클래스는 전달 된 원시 텍스트를 토큰 화하는 데 사용됩니다. 이 메서드는 문자열 변수를 매개 변수로 받아들이고 문자열 (토큰) 배열을 반환합니다.
다음과 같이 문장의 문자열 형식을이 메서드에 전달하여이 메서드를 호출합니다.
//Tokenizing the given raw text
String tokens[] = tokenizer.tokenize(paragraph);
Example
다음은 주어진 원시 텍스트를 토큰 화하는 프로그램입니다. 이 프로그램을 이름의 파일에 저장하십시오.TokenizerMEExample.java.
import java.io.FileInputStream;
import java.io.InputStream;
import opennlp.tools.tokenize.TokenizerME;
import opennlp.tools.tokenize.TokenizerModel;
public class TokenizerMEExample {
public static void main(String args[]) throws Exception{
String sentence = "Hi. How are you? Welcome to Tutorialspoint. "
+ "We provide free tutorials on various technologies";
//Loading the Tokenizer model
InputStream inputStream = new FileInputStream("C:/OpenNLP_models/en-token.bin");
TokenizerModel tokenModel = new TokenizerModel(inputStream);
//Instantiating the TokenizerME class
TokenizerME tokenizer = new TokenizerME(tokenModel);
//Tokenizing the given raw text
String tokens[] = tokenizer.tokenize(sentence);
//Printing the tokens
for (String a : tokens)
System.out.println(a);
}
}
다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.
javac TokenizerMEExample.java
java TokenizerMEExample
실행시 위의 프로그램은 주어진 문자열을 읽고 그 안의 문장을 감지하고 다음 출력을 표시합니다.
Hi
.
How
are
you
?
Welcome
to
Tutorialspoint
.
We
provide
free
tutorials
on
various
technologie
토큰 위치 검색
우리는 또한 위치를 얻거나 spans 사용하는 토큰의 tokenizePos()방법. 이것은 패키지의 Tokenizer 인터페이스 방법입니다.opennlp.tools.tokenize. 모든 (3) Tokenizer 클래스가이 인터페이스를 구현하므로 모든 클래스에서이 메서드를 찾을 수 있습니다.
이 메서드는 문자열 형식의 문장 또는 원시 텍스트를 받아들이고 해당 유형의 개체 배열을 반환합니다. Span.
다음을 사용하여 토큰의 위치를 얻을 수 있습니다. tokenizePos() 방법, 다음과 같이-
//Retrieving the tokens
tokenizer.tokenizePos(sentence);
위치 (스팬) 인쇄
명명 된 클래스 Span 의 opennlp.tools.util 패키지는 집합의 시작 및 끝 정수를 저장하는 데 사용됩니다.
반환 된 스팬을 저장할 수 있습니다. tokenizePos() 다음 코드 블록과 같이 Span 배열에 메서드를 추가하고 인쇄합니다.
//Retrieving the tokens
Span[] tokens = tokenizer.tokenizePos(sentence);
//Printing the spans of tokens
for( Span token : tokens)
System.out.println(token);
토큰과 그 위치를 함께 인쇄
그만큼 substring() String 클래스의 메서드는 begin 그리고 end오프셋하고 각 문자열을 반환합니다. 다음 코드 블록에 표시된 것처럼이 메서드를 사용하여 토큰과 해당 범위 (위치)를 함께 인쇄 할 수 있습니다.
//Printing the spans of tokens
for(Span token : tokens)
System.out.println(token +" "+sent.substring(token.getStart(), token.getEnd()));
Example(SimpleTokenizer)
다음은 다음을 사용하여 원시 텍스트의 토큰 범위를 검색하는 프로그램입니다. SimpleTokenizer수업. 또한 위치와 함께 토큰을 인쇄합니다. 이 프로그램을 이름이 지정된 파일에 저장하십시오.SimpleTokenizerSpans.java.
import opennlp.tools.tokenize.SimpleTokenizer;
import opennlp.tools.util.Span;
public class SimpleTokenizerSpans {
public static void main(String args[]){
String sent = "Hi. How are you? Welcome to Tutorialspoint. "
+ "We provide free tutorials on various technologies";
//Instantiating SimpleTokenizer class
SimpleTokenizer simpleTokenizer = SimpleTokenizer.INSTANCE;
//Retrieving the boundaries of the tokens
Span[] tokens = simpleTokenizer.tokenizePos(sent);
//Printing the spans of tokens
for( Span token : tokens)
System.out.println(token +" "+sent.substring(token.getStart(), token.getEnd()));
}
}
다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.
javac SimpleTokenizerSpans.java
java SimpleTokenizerSpans
실행시 위의 프로그램은 주어진 문자열 (원시 텍스트)을 읽고 토큰 화하고 다음 출력을 표시합니다.
[0..2) Hi
[2..3) .
[4..7) How
[8..11) are
[12..15) you
[15..16) ?
[17..24) Welcome
[25..27) to
[28..42) Tutorialspoint
[42..43) .
[44..46) We
[47..54) provide
[55..59) free
[60..69) tutorials
[70..72) on
[73..80) various
[81..93) technologies
Example (WhitespaceTokenizer)
다음은 다음을 사용하여 원시 텍스트의 토큰 범위를 검색하는 프로그램입니다. WhitespaceTokenizer수업. 또한 위치와 함께 토큰을 인쇄합니다. 이 프로그램을 이름의 파일에 저장하십시오.WhitespaceTokenizerSpans.java.
import opennlp.tools.tokenize.WhitespaceTokenizer;
import opennlp.tools.util.Span;
public class WhitespaceTokenizerSpans {
public static void main(String args[]){
String sent = "Hi. How are you? Welcome to Tutorialspoint. "
+ "We provide free tutorials on various technologies";
//Instantiating SimpleTokenizer class
WhitespaceTokenizer whitespaceTokenizer = WhitespaceTokenizer.INSTANCE;
//Retrieving the tokens
Span[] tokens = whitespaceTokenizer.tokenizePos(sent);
//Printing the spans of tokens
for( Span token : tokens)
System.out.println(token +"
"+sent.substring(token.getStart(), token.getEnd()));
}
}
다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.
javac WhitespaceTokenizerSpans.java
java WhitespaceTokenizerSpans
실행시 위 프로그램은 주어진 문자열 (원시 텍스트)을 읽고이를 토큰 화하고 다음 출력을 표시합니다.
[0..3) Hi.
[4..7) How
[8..11) are
[12..16) you?
[17..24) Welcome
[25..27) to
[28..43) Tutorialspoint.
[44..46) We
[47..54) provide
[55..59) free
[60..69) tutorials
[70..72) on
[73..80) various
[81..93) technologies
Example (TokenizerME)
다음은 다음을 사용하여 원시 텍스트의 토큰 범위를 검색하는 프로그램입니다. TokenizerME수업. 또한 위치와 함께 토큰을 인쇄합니다. 이 프로그램을 이름의 파일에 저장하십시오.TokenizerMESpans.java.
import java.io.FileInputStream;
import java.io.InputStream;
import opennlp.tools.tokenize.TokenizerME;
import opennlp.tools.tokenize.TokenizerModel;
import opennlp.tools.util.Span;
public class TokenizerMESpans {
public static void main(String args[]) throws Exception{
String sent = "Hello John how are you welcome to Tutorialspoint";
//Loading the Tokenizer model
InputStream inputStream = new FileInputStream("C:/OpenNLP_models/en-token.bin");
TokenizerModel tokenModel = new TokenizerModel(inputStream);
//Instantiating the TokenizerME class
TokenizerME tokenizer = new TokenizerME(tokenModel);
//Retrieving the positions of the tokens
Span tokens[] = tokenizer.tokenizePos(sent);
//Printing the spans of tokens
for(Span token : tokens)
System.out.println(token +" "+sent.substring(token.getStart(), token.getEnd()));
}
}
다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.
javac TokenizerMESpans.java
java TokenizerMESpans
실행시 위의 프로그램은 주어진 문자열 (원시 텍스트)을 읽고 토큰 화하고 다음 출력을 표시합니다.
[0..5) Hello
[6..10) John
[11..14) how
[15..18) are
[19..22) you
[23..30) welcome
[31..33) to
[34..48) Tutorialspoint
토큰 화 확률
TokenizerME 클래스의 getTokenProbabilities () 메서드는 tokenizePos () 메서드에 대한 가장 최근 호출과 관련된 확률을 가져 오는 데 사용됩니다.
//Getting the probabilities of the recent calls to tokenizePos() method
double[] probs = detector.getSentenceProbabilities();
다음은 tokenizePos () 메서드 호출과 관련된 확률을 인쇄하는 프로그램입니다. 이 프로그램을 이름의 파일에 저장하십시오.TokenizerMEProbs.java.
import java.io.FileInputStream;
import java.io.InputStream;
import opennlp.tools.tokenize.TokenizerME;
import opennlp.tools.tokenize.TokenizerModel;
import opennlp.tools.util.Span;
public class TokenizerMEProbs {
public static void main(String args[]) throws Exception{
String sent = "Hello John how are you welcome to Tutorialspoint";
//Loading the Tokenizer model
InputStream inputStream = new FileInputStream("C:/OpenNLP_models/en-token.bin");
TokenizerModel tokenModel = new TokenizerModel(inputStream);
//Instantiating the TokenizerME class
TokenizerME tokenizer = new TokenizerME(tokenModel);
//Retrieving the positions of the tokens
Span tokens[] = tokenizer.tokenizePos(sent);
//Getting the probabilities of the recent calls to tokenizePos() method
double[] probs = tokenizer.getTokenProbabilities();
//Printing the spans of tokens
for(Span token : tokens)
System.out.println(token +" "+sent.substring(token.getStart(), token.getEnd()));
System.out.println(" ");
for(int i = 0; i<probs.length; i++)
System.out.println(probs[i]);
}
}
다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.
javac TokenizerMEProbs.java
java TokenizerMEProbs
실행시 위의 프로그램은 주어진 문자열을 읽고 문장을 토큰 화하고 인쇄합니다. 또한 tokenizerPos () 메서드에 대한 가장 최근 호출과 관련된 확률도 반환합니다.
[0..5) Hello
[6..10) John
[11..14) how
[15..18) are
[19..22) you
[23..30) welcome
[31..33) to
[34..48) Tutorialspoint
1.0
1.0
1.0
1.0
1.0
1.0
1.0
1.0