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);

위치 (스팬) 인쇄

명명 된 클래스 Spanopennlp.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