如何解决使用googletrans
所以我想使用Textblob情感来计算我的数据的情感。但是,在计算情感之前,我将数据从印尼语转换为英语。
这是我的密码
import pandas as pd
df = pd.read_csv('file.csv',encoding="utf-16")
from googletrans import Translator
translator = Translator()
df['english'] = df['Comment'].apply(translator.translate,src='id',dest='en')
#print(df)
#print(df['english'])
from textblob import TextBlob
def sentiment_calc(text):
try:
return TextBlob(text).sentiment
except:
return None
df['sentiment']=df['english'].apply(lambda text: TextBlob(text).sentiment)
print(df['sentiment'])
但是后来我得到了这个错误
TypeError: The `text` argument passed to `__init__(text)` must be a string,not <class 'googletrans.models.Translated'>
有解决方案吗?顺便说一下,翻译结果很好。
解决方法
发生错误是因为您给TextBlob提供了字符串以外的其他内容。df['english']
的类型为<class 'googletrans.models.Translated'>
,因此必须将其更改为字符串。
import pandas as pd
df = pd.read_csv('file.csv',encoding="utf-8")
from googletrans import Translator
translator = Translator()
df['english'] = df['Comment'].apply(translator.translate,src='id',dest='en')
#print(df)
#print(df['english'])
from textblob import TextBlob
def sentiment_calc(text):
try:
return TextBlob(text).sentiment
except:
return None
df['english'] = df['english'].astype(str) #change type to string
df['sentiment']=df['english'].apply(lambda text: TextBlob(text).sentiment)
print(df['sentiment'])
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。