猿问

如何解决 tf-idf 词汇错误?

我在训练数据上从 sklearn 训练了一个 TFIDF,当我将词汇应用到新数据上时,它给了我一个关键错误,因为它没有从中学习。我该如何解决它?


这是我的代码。


   def feature_engineering(self, inputs):

        x = [self.analyser(seq) for seq in inputs]

        return x


    def fit(self, inputs):

        if self.vocabulary and self.analyser:

            pass

        else:

            vectorizer = TfidfVectorizer(

                ngram_range=(self.config_dict["min_n_gram"], self.config_dict["max_n_gram"]), lowercase=False,

                stop_words=None,min_df=2)

            vectorizer.fit(inputs)

            self.analyser = vectorizer.build_analyzer()

            self.vocabulary = vectorizer.vocabulary_

            save_object(os.path.join(self.feature_extraction_folder, "analyzer.pickle"), self.analyser)

            save_object(os.path.join(self.feature_extraction_folder, "vocabulary.pickle"), self.vocabulary)


    def transform(self, inputs):

        vocab_size = len(self.vocabulary)

        inputs = self.feature_engineering(inputs)

        inputs = [[self.vocabulary[x] for x in l] for l in inputs]##This line generate an error


        return np.array(inputs)


潇潇雨雨
浏览 86回答 1
1回答

慕少森

使用 if 语句解决我的问题inputs = [[self.vocabulary[x] for x in l if x in self.vocabulary.keys()] for l in inputs]```
随时随地看视频慕课网APP

相关分类

Python
我要回答