So nutzen Sie maschinelles Lernen zur Stimmungsanalyse

王林
Freigeben: 2023-04-11 16:49:03
nach vorne
2205 Leute haben es durchsucht

So nutzen Sie maschinelles Lernen zur Stimmungsanalyse

Wir haben verschiedene maschinelle Lernalgorithmen für die Stimmungsanalyse verwendet und dann die Genauigkeitsergebnisse jedes Algorithmus verglichen, um zu bestimmen, welcher Algorithmus für dieses Problem am besten geeignet ist.

Stimmungsanalyse ist ein wichtiger Inhalt in der Verarbeitung natürlicher Sprache (NLP). Emotionen sind die Gefühle, die wir in Bezug auf ein Ereignis, einen Gegenstand, eine Situation oder eine Sache haben. Die Stimmungsanalyse ist ein Forschungsgebiet, das automatisch menschliche Emotionen aus Texten extrahiert. Die langsame Entwicklung begann Anfang der 90er Jahre.

In diesem Artikel erfahren Sie, wie Sie maschinelles Lernen (ML) für die Stimmungsanalyse verwenden und die Ergebnisse verschiedener maschineller Lernalgorithmen vergleichen. Das Ziel dieses Artikels besteht nicht darin, zu untersuchen, wie die Leistung des Algorithmus verbessert werden kann.

Heutzutage leben wir in einer schnelllebigen Gesellschaft, alle Waren können online gekauft werden und jeder kann seine eigenen Kommentare online posten. Und negative Online-Bewertungen einiger Produkte können dem Ruf des Unternehmens schaden und sich dadurch auf den Umsatz des Unternehmens auswirken. Daher ist es für Unternehmen sehr wichtig, Produktbewertungen zu nutzen, um zu verstehen, was Kunden wirklich wollen. Es sind jedoch zu viele Kommentardaten vorhanden und es ist unmöglich, alle Kommentare einzeln manuell anzuzeigen. So entstand die Sentimentanalyse.

Sehen wir uns nun an, wie man maschinelles Lernen nutzt, um ein Modell zur Durchführung einer grundlegenden Stimmungsanalyse zu entwickeln.

Jetzt starten!

Daten abrufen

Der erste Schritt besteht darin, einen Datensatz auszuwählen. Sie können aus jeder öffentlichen Rezension wählen, beispielsweise einem Tweet oder einer Filmrezension. Der Datensatz muss mindestens zwei Spalten enthalten: Beschriftungen und tatsächliche Textsegmente.

Die folgende Abbildung zeigt einige der von uns ausgewählten Datensätze.

Figure 1: Data sample

Abbildung 1: Datenbeispiel

Als nächstes importieren wir die erforderlichen Bibliotheken:

import pandas as pd
import numpy as np
from nltk.stem.porter import PorterStemmer
import re
import string
Nach dem Login kopieren

Wie Sie im Code oben sehen können, haben wir ​​NumPy​​ und ​​Pandas​​ Was andere Bibliotheken betrifft, werden wir sie bei ihrer Verwendung erläutern. ​NumPy​​ 和 ​​Pandas​​ 库来处理数据。至于其他库,我们会在使用到它们时再说明。

数据集已准备就绪,并且已导入所需的库。接着,我们需要用 ​​Pandas​​ 库将数据集读入到我们的项目中去。我们使用以下的代码将数据集读入 Pandas 数据帧DataFrame

sentiment_dataframe = pd.read_csv(“/content/drive/MyDrive/Data/sentiments - sentiments.tsv”,sep = ‘t’)
Nach dem Login kopieren

数据处理

现在我们的项目中已经导入好数据集了。然后,我们要对数据进行处理,以便算法可以更好地理解数据集的特征。我们首先为数据集中的列命名,通过下面的代码来完成:

sentiment_dataframe.columns = [“label”,”body_text”]
Nach dem Login kopieren

然后,我们对 ​​label​​ 列进行数值化:​​negative​​ 的评论替换为 1,​​positive​​ 的评论替换为 0。下图显示了经过基本修改后的 ​​sentiment_dataframe​

Der Datensatz ist fertig und die erforderlichen Bibliotheken wurden importiert. Als nächstes müssen wir ​​Pandas​​ Bibliothek liest den Datensatz in unser Projekt. Wir verwenden den folgenden Code, um den Datensatz in Pandas DataFrame einzulesen

def count_punct(text):
 count = sum([1 for char in text if char in string.punctuation])
 return round(count/(len(text) - text.count(“ “)),3)*100
 
tokenized_tweet = sentiment_dataframe[‘body_text’].apply(lambda x: x.split())
stemmer = PorterStemmer()
tokenized_tweet = tokenized_tweet.apply(lambda x: [stemmer.stem(i) for i in x])
for i in range(len(tokenized_tweet)):
 tokenized_tweet[i] = ‘ ‘.join(tokenized_tweet[i])
sentiment_dataframe[‘body_text’] = tokenized_tweet
sentiment_dataframe[‘body_len’] = sentiment_dataframe[‘body_text’].apply(lambda x:len(x) - x.count(“ “))
sentiment_dataframe[‘punct%’] = sentiment_dataframe[‘body_text’].apply(lambda x:count_punct(x))
X = sentiment_dataframe[‘body_text’]
y = sentiment_dataframe[‘label’]
Nach dem Login kopieren
Nach dem Login kopieren
Figure 2: Data frame with basic modificationsDatenverarbeitung

Jetzt wurde der Datensatz in unser Projekt importiert. Anschließend verarbeiten wir die Daten, damit der Algorithmus die Eigenschaften des Datensatzes besser verstehen kann. Wir benennen zunächst die Spalten im Datensatz, was mit dem folgenden Code erfolgt:

from sklearn.model_selection import train_test_split
X_train, X_test, y_train, y_test = train_test_split(X,y, test_size = 0.20, random_state = 99)
Nach dem Login kopieren
Nach dem Login kopieren
Dann benennen wir die Spalten im Datensatz: 4px; overflow-wrap: break-word;">​label ​​ Numerischer Spaltenwert: ​​negative​​ Kommentare werden durch 1,​​positive​​ Kommentare werden durch 0 ersetzt. Das Bild unten zeigt die grundlegende Änderung: ​sentiment_dataframe​​ Wert.

🎜Abbildung 2: Datenrahmen mit grundlegenden Modifikationen🎜🎜🎜Merkmalswerte und Zielwerte vorbereiten🎜🎜Der nächste Schritt ist die Datenvorverarbeitung. Dies ist ein sehr wichtiger Schritt, da maschinelle Lernalgorithmen nur numerische Daten verstehen/verarbeiten können, nicht jedoch Text. Daher ist zu diesem Zeitpunkt eine Merkmalsextraktion erforderlich, um Zeichenfolgen/Text in numerische Daten umzuwandeln. Darüber hinaus müssen redundante und nutzlose Daten entfernt werden, da diese Daten unser trainiertes Modell verunreinigen können. In diesem Schritt entfernen wir verrauschte Daten, fehlende Wertdaten und inkonsistente Daten. 🎜

对于情感分析,我们在数据帧中添加特征文本的长度和标点符号计数。我们还要进行词干提取,即将所有相似词(如 “give”、“giving” 等)转换为单一形式。完成后,我们将数据集分为两部分:特征值 X 和 目标值 Y。

上述内容是使用以下代码完成的。下图显示了执行这些步骤后的数据帧。

Figure 3: Data frame after the division of the data set

Figure 3: Data frame after the division of the data set

def count_punct(text):
 count = sum([1 for char in text if char in string.punctuation])
 return round(count/(len(text) - text.count(“ “)),3)*100
 
tokenized_tweet = sentiment_dataframe[‘body_text’].apply(lambda x: x.split())
stemmer = PorterStemmer()
tokenized_tweet = tokenized_tweet.apply(lambda x: [stemmer.stem(i) for i in x])
for i in range(len(tokenized_tweet)):
 tokenized_tweet[i] = ‘ ‘.join(tokenized_tweet[i])
sentiment_dataframe[‘body_text’] = tokenized_tweet
sentiment_dataframe[‘body_len’] = sentiment_dataframe[‘body_text’].apply(lambda x:len(x) - x.count(“ “))
sentiment_dataframe[‘punct%’] = sentiment_dataframe[‘body_text’].apply(lambda x:count_punct(x))
X = sentiment_dataframe[‘body_text’]
y = sentiment_dataframe[‘label’]
Nach dem Login kopieren
Nach dem Login kopieren

特征工程:文本特征处理

我们接下来进行文本特征抽取,对文本特征进行数值化。为此,我们使用计数向量器CountVectorizer,它返回词频矩阵。

在此之后,计算数据帧 X 中的文本长度和标点符号计数等特征。X 的示例如下图所示。

Figure 4: Sample of final features

Figure 4: Sample of final features

使用的机器学习算法

现在数据已经可以训练了。下一步是确定使用哪些算法来训练模型。如前所述,我们将尝试多种机器学习算法,并确定最适合情感分析的算法。由于我们打算对文本进行二元分类,因此我们使用以下算法:

  • K-近邻算法(KNN)
  • 逻辑回归算法
  • 支持向量机(SVMs)
  • 随机梯度下降(SGD)
  • 朴素贝叶斯算法
  • 决策树算法
  • 随机森林算法

划分数据集

首先,将数据集划分为训练集和测试集。使用 ​​sklearn​​ 库,详见以下代码:

from sklearn.model_selection import train_test_split
X_train, X_test, y_train, y_test = train_test_split(X,y, test_size = 0.20, random_state = 99)
Nach dem Login kopieren
Nach dem Login kopieren

我们使用 20% 的数据进行测试,80% 的数据用于训练。划分数据的意义在于对一组新数据(即测试集)评估我们训练的模型是否有效。

K-近邻算法

现在,让我们开始训练第一个模型。首先,我们使用 KNN 算法。先训练模型,然后再评估模型的准确率(具体的代码都可以使用 Python 的 ​​sklearn​​ 库来完成)。详见以下代码,KNN 训练模型的准确率大约为 50%。

from sklearn.neighbors import KNeighborsClassifier
model = KNeighborsClassifier(n_neighbors=3)
model.fit(X_train, y_train)
model.score (X_test,y_test)
0.5056689342403629
Nach dem Login kopieren
逻辑回归算法

逻辑回归模型的代码十分类似——首先从库中导入函数,拟合模型,然后对模型进行评估。下面的代码使用逻辑回归算法,准确率大约为 66%。

from sklearn.linear_model import LogisticRegression
model = LogisticRegression()
model.fit (X_train,y_train)
model.score (X_test,y_test)
0.6621315192743764
Nach dem Login kopieren
支持向量机算法

以下代码使用 SVM,准确率大约为 67%。

from sklearn import svm
model = svm.SVC(kernel=’linear’)
model.fit(X_train, y_train)
model.score(X_test,y_test)
0.6780045351473923
Nach dem Login kopieren
随机森林算法

以下的代码使用了随机森林算法,随机森林训练模型的准确率大约为 69%。

from sklearn.ensemble import RandomForestClassifier
model = RandomForestClassifier()
model.fit(X_train, y_train)
model.score(X_test,y_test)
0.6938775510204082
Nach dem Login kopieren
决策树算法

接下来,我们使用决策树算法,其准确率约为 61%。

from sklearn.tree import DecisionTreeClassifier
model = DecisionTreeClassifier()
model = model.fit(X_train,y_train)
model.score(X_test,y_test)
0.6190476190476191
Nach dem Login kopieren
随机梯度下降算法

以下的代码使用随机梯度下降算法,其准确率大约为 49%。

from sklearn.linear_model import SGDClassifier
model = SGDClassifier()
model = model.fit(X_train,y_train)
model.score(X_test,y_test)
0.49206349206349204
Nach dem Login kopieren
朴素贝叶斯算法

以下的代码使用朴素贝叶斯算法,朴素贝叶斯训练模型的准确率大约为 60%。

from sklearn.naive_bayes import GaussianNB
model = GaussianNB()
model.fit(X_train, y_train)
model.score(X_test,y_test)
0.6009070294784581
Nach dem Login kopieren

情感分析的最佳算法

接下来,我们绘制所有算法的准确率图。如下图所示。

Figure 5: Accuracy performance of the different algorithms

Figure 5: Accuracy performance of the different algorithms

可以看到,对于情感分析这一问题,随机森林算法有最佳的准确率。由此,我们可以得出结论,随机森林算法是所有机器算法中最适合情感分析的算法。我们可以通过处理得到更好的特征、尝试其他矢量化技术、或者使用更好的数据集或更好的分类算法,来进一步提高准确率。

既然,随机森林算法是解决情感分析问题的最佳算法,我将向你展示一个预处理数据的样本。在下图中,你可以看到模型会做出正确的预测!试试这个来改进你的项目吧!

Figure 6: Sample predictions made

Abbildung 6: Beispielvorhersagen

Das obige ist der detaillierte Inhalt vonSo nutzen Sie maschinelles Lernen zur Stimmungsanalyse. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:51cto.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!