我有一个文本文件和2个用户定义的正面和负面文件。我将2个文件中出现的单词与文本文件进行比较,然后返回正数或负数。
但我需要在文本中打印这些关键字,将其分类为正面或负面。
我正在寻找的输出示例:
file_name IBM Keywords Label
audio1.wav The customer is good good Positive
audio2.wav the service is bad bad Negative
请让我知道如何去做。这是迄今为止的代码
pos = readwords('C:\\Users\\anagha\\Desktop\\SynehackData\\positive.txt')
neg = readwords('C:\\Users\\anagha\\Desktop\\SynehackData\\Negative.txt')
pos = [w.lower() for w in pos]
neg = [w.lower() for w in neg]
def assign_comments_labels(x):
try:
if any(w in x for w in pos) :
return 'positive'
elif any(w in x for w in neg):
return 'negative'
else:
return 'neutral'
except:
return 'neutral'
import pandas as pd
df = pd.read_csv("C:\\Users\\anagha\\Desktop\\SynehackData\\noise_free_audio\\outputfile.csv", encoding="utf-8")
df['IBM'] = df['IBM'].str.lower()
df['file_name'] = df['file_name'].str.lower()
df['labels'] = df['IBM'].apply(lambda x: assign_comments_labels(x))
df[['file_name','IBM','labels']]
答案 0 :(得分:1)
一个好的开始是在assign_comments_labels(x)函数中有正确的缩进。 缩进整个身体。
编辑回答:
好的,我现在得到你的问题;
根据您在上面使用的逻辑,此代码应该适合您:
def get_keyword(x):
x_ = x.split(" ")
try:
for word in x_:
if (word in neg) or (word in pos):
return word
except:
return -1
return -1
然后可以像对标签一样使用lambda:
df['keywords'] = df['IBM'].apply(lambda x: get_keyword(x))
编辑2 :
要为每个句子返回多个关键字,您可以修改代码以返回列表;
def get_keyword(x):
x_ = x.split(" ")
keywords = []
try:
for word in x_:
if (word in neg) or (word in pos):
keywords.append(word)
except:
return -1
return keywords
更好的解决方案是创建两个函数
而不是DataFrame中关键字的一列,您将有两个,一个用于pos,一个用于neg。
通常,文本会同时包含正面和负面关键字,但每个单词的权重会将句子的最终结果分类为正面或负面。如果这是你的情况,那么我强烈建议你实施第二个解决方案。
注意:
对于第二个解决方案,将if语句更改为
# For positive keywords function
if word in pos:
keywords.append(word)
# For negative keywords function
if word in neg:
keywords.append(word)
希望有所帮助