gpt4 book ai didi

python - 如何使用 scikit-learn 对文本对进行分类?

转载 作者:太空宇宙 更新时间:2023-11-04 05:11:40 25 4
gpt4 key购买 nike

我已经阅读了许多关于这个主题的不同博客,但未能找到明确的解决方案。我有以下场景:

  1. 我有一个标签为 1 或 -1 的文本对列表。
  2. 对于每个文本对,我希望特征按以下方式串联:f () = tfidf(t1) "concat"tfidf(t2)

关于如何做同样的事情有什么建议吗?我有以下代码,但它给出了一个错误:

    count_vect = TfidfVectorizer(analyzer=u'char', ngram_range=ngram_range)
X0_train_counts = count_vect.fit_transform([x[0] for x in training_documents])
X1_train_counts = count_vect.fit_transform([x[1] for x in training_documents])
combined_features = FeatureUnion([("x0", X0_train_counts), ("x1", X1_train_counts)])
clf = LinearSVC().fit(combined_features, training_target)
average_training_accuracy += clf.score(combined_features, training_target)

这是我得到的错误:

---------------------------------------------------------------------------
TypeError Traceback (most recent call last)
scoreEdgesUsingClassifier(None, pos, neg, 1,ngram_range=(2,5), max_size=1000000, test_size=100000)

scoreEdgesUsingClassifier(unc, pos, neg, number_of_iterations, ngram_range, max_size, test_size)
X0_train_counts = count_vect.fit_transform([x[0] for x in training_documents])
X1_train_counts = count_vect.fit_transform([x[1] for x in training_documents])
combined_features = FeatureUnion([("x0", X0_train_counts), ("x1", X1_train_counts)])
print "Done transforming, now training classifier"

lib/python2.7/site-packages/sklearn/pipeline.pyc in __init__(self, transformer_list, n_jobs, transformer_weights)
616 self.n_jobs = n_jobs
617 self.transformer_weights = transformer_weights
--> 618 self._validate_transformers()
619
620 def get_params(self, deep=True):

lib/python2.7/site-packages/sklearn/pipeline.pyc in _validate_transformers(self)
660 raise TypeError("All estimators should implement fit and "
661 "transform. '%s' (type %s) doesn't" %
--> 662 (t, type(t)))
663
664 def _iter(self):

TypeError: All estimators should implement fit and transform. ' (0, 49025) 0.0575144797079

(254741, 38401) 0.184394443164
(254741, 201747) 0.186080393768
(254741, 179231) 0.195062580945
(254741, 156925) 0.211367771299
(254741, 90026) 0.202458920022' (type <class 'scipy.sparse.csr.csr_matrix'>) doesn't

更新

解决方法如下:

    count_vect = TfidfVectorizer(analyzer=u'char', ngram_range=ngram_range)
training_docs_combined = [x[0] for x in training_documents] + [x[1] for x in training_documents]
X_train_counts = count_vect.fit_transform(training_docs_combined)
concat_features = hstack((X_train_counts[0:len(training_docs_combined) / 2 ], X_train_counts[len (training_docs_combined) / 2:]))

clf = LinearSVC().fit(concat_features, training_target)
average_training_accuracy += clf.score(concat_features, training_target)

最佳答案

scikit-learn 中的

FeatureUnion 将输入估算器而不是数据数组作为输入。

您可以简单地使用 scipy.sparse.hstack 连接生成的 X0_train_countsX1_train_counts 数组,或者创建 的两个独立实例>TfidfVectorizer,对它们应用FeatureUnion,然后调用fit_transform方法。

关于python - 如何使用 scikit-learn 对文本对进行分类?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42844491/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com