forked from shubham721/Sentiment-Analysis-On-Hindi-Reviews
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ResourceBasedSentimentClassification.py
79 lines (71 loc) · 2.82 KB
/
ResourceBasedSentimentClassification.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
# This module is written to do a Resource Based Semantic analyasis using hindi sentiwordnet.
import pandas as pd
import codecs
from nltk.tokenize import word_tokenize
from sklearn.metrics.classification import accuracy_score
from sklearn.metrics import f1_score
import re
data = pd.read_csv("HindiSentiWordnet.txt", delimiter=' ')
fields = ['POS_TAG', 'ID', 'POS', 'NEG', 'LIST_OF_WORDS']
#Creating a dictionary which contain a tuple for every word. Tuple contains a list of synonyms,
# positive score and negative score for that word.
words_dict = {}
for i in data.index:
# print (data[fields[0]][i], data[fields[1]][i], data[fields[2]][i], data[fields[3]][i], data[fields[4]][i])
words = data[fields[4]][i].split(',')
for word in words:
words_dict[word] = (data[fields[0]][i], data[fields[2]][i], data[fields[3]][i])
# This function determines sentiment of text.
def sentiment(text):
words = word_tokenize(text)
votes = []
pos_polarity = 0
neg_polarity = 0
#adverbs, nouns, adjective, verb are only used
allowed_words = ['a','v','r','n']
for word in words:
if word in words_dict:
#if word in dictionary, it picks up the positive and negative score of the word
pos_tag, pos, neg = words_dict[word]
# print(word, pos_tag, pos, neg)
if pos_tag in allowed_words:
if pos > neg:
pos_polarity += pos
votes.append(1)
elif neg > pos:
neg_polarity += neg
votes.append(0)
#calculating the no. of positive and negative words in total in a review to give class labels
pos_votes = votes.count(1)
neg_votes = votes.count(0)
if pos_votes > neg_votes:
return 1
elif neg_votes > pos_votes:
return 0
else:
if pos_polarity < neg_polarity:
return 0
else:
return 1
pred_y = []
actual_y = []
# to calculate accuracy
pos_reviews = codecs.open("pos_hindi.txt", "r", encoding='utf-8', errors='ignore').read()
for line in pos_reviews.split('$'):
data = line.strip('\n')
if data:
pred_y.append(sentiment(data))
actual_y.append(1)
#print(accuracy_score(actual_y, pred_y) * 100)
print(len(actual_y))
neg_reviews = codecs.open("neg_hindi.txt", "r", encoding='utf-8', errors='ignore').read()
for line in neg_reviews.split('$'):
data=line.strip('\n')
if data:
pred_y.append(sentiment(data))
actual_y.append(0)
print(len(actual_y))
print(accuracy_score(actual_y, pred_y) * 100)
print('F-measure: ',f1_score(actual_y,pred_y))
# if __name__ == '__main__':
#print(sentiment("मैं इस उत्पाद से बहुत खुश हूँ यह आराम दायक और सुन्दर है यह खरीदने लायक है "))