2

Java wordnet インターフェース JWIを使用して単語のハイパーニムを生成し、特定のエンティティから高次の概念/タイプに一般化します。

isa私のコードの一部では、単語が wordnetに登録されていることを確認したい部分がありますis a。これは私が今これを試している方法です。

public void getHypernyms( String inut_word ) throws IOException
{   

    // get the synset of 'input_word'
    //IIndexWord idxWord = dict . getIndexWord (inut_word, POS . NOUN ) ;
    IIndexWord idxWord = dict.getIndexWord( inut_word, POS.VERB );

    if( idxWord != null && idxWord.size() > 0)

    IWordID wordID = idxWord.getWordIDs().get (0); // 1st meaning
    IWord word = dict.getWord( wordID );
    ISynset synset = word.getSynset();

    // get the hypernyms
    List < ISynsetID > hypernyms = synset.getRelatedSynsets( Pointer.HYPERNYM );

    if( hypernyms.size() > 0)
    {
        // print out each hypernyms id and synonyms
        List < IWord > words;
        for( ISynsetID sid : hypernyms ) 
        {
            words = dict.getSynset( sid ).getWords ();
            System.out.print( sid + " {");
            for( Iterator <IWord> i = words.iterator(); i.hasNext(); ) 
            {
                System.out.print( i.next().getLemma() );
                if( i.hasNext() )
                    System.out.print(", ");
            }
            System.out.println("}");
        }
    }
    else
    {
        System.out.println( inut_word );
    }


}

しかし、日食は私にそれを警告しますmethod size() is not defined for type IIndexWord

@overrideこれは、サイズを調整する必要があることを意味していると思いますよね?しかし、私は実際にそれをやったことがないのですが、どうすればいいですか?

具体的には java.util.List.size です。

私はこの方法をこのように実装しようとしていましたが、それは魅力のように機能します。

public String getStem(String word)
{
    WordnetStemmer stem =  new WordnetStemmer( dict );

    List<String> stemmed_words = stem.findStems(word,  POS.VERB);

    if( stemmed_words != null && stemmed_words.size() > 0)
        return stemmed_words.get(0);
    else
        return word;
}
4

2 に答える 2

1

@Titusの助けを借りて、私はそれを手に入れました

public void getHypernyms( String input_word ) throws IOException
{   
    System.out.println( "input_word : " + input_word);
    // get the synset of 'input_word'
    //IIndexWord idxWord = dict . getIndexWord (inut_word, POS . NOUN ) ;
    IIndexWord idxWord = dict.getIndexWord( input_word, POS.VERB );

    if(dict.getIndexWord( input_word, POS.VERB ) == null)
    {
        System.out.println( "got ya'!");
    }
    else
    {

        System.out.println( "idxWord: " + idxWord );
        IWordID wordID = idxWord.getWordIDs().get(0); // 1st meaning
        IWord word = dict.getWord( wordID );
        ISynset synset = word.getSynset();

        // get the hypernyms
        List < ISynsetID > hypernyms = synset.getRelatedSynsets( Pointer.HYPERNYM );

        if( hypernyms.size() > 0)
        {
            // print out each hypernyms id and synonyms
            List < IWord > words;
            for( ISynsetID sid : hypernyms ) 
            {
                words = dict.getSynset( sid ).getWords ();
                System.out.print( sid + " {");
                for( Iterator <IWord> i = words.iterator(); i.hasNext(); ) 
                {
                    System.out.print( i.next().getLemma() );
                    if( i.hasNext() )
                        System.out.print(", ");
                }
                System.out.println("}");
            }
        }


    }

}
于 2015-01-30T06:57:10.053 に答える
0

これが問題の原因となっている行だと思います

 if( idxWord != null && idxWord.size() > 0)

ドキュメントを見てみましたが、メソッドIIndexWordがないようです。size()null ポインタの例外と範囲外のインデックスの例外を回避するには、次のようなチェックを行うことができます。

if(idxWord != null && idxWord.getWordIDs() != null && idxWord.getWordIDs().size() > 0)
于 2015-01-30T06:23:59.580 に答える