gpt4 book ai didi

python - 使用 spacy 对 Pandas Dataframe 中的一列已解析的 html 文本进行词形还原

转载 作者:行者123 更新时间:2023-12-05 02:06:34 25 4
gpt4 key购买 nike

我想做一些非常琐碎的事情,但很难编写实现它的函数。对于 NLP 多类分类任务,我必须预处理 pandas DataFrame。感兴趣的列是已解析的 html 文本(列:“tweet”)。我规范化我的数据(小写,删除标点符号,停用词,...),然后我想使用 spacy 对其进行词形还原并将其作为列写回。但是,我不能把这个功能放在一起。我在 SO 上找到了几个示例,但它们都使用列表,我无法将其转换为 DF。因为我有一个非常大的 DataFrame (10GB),所以我想使用一个不太慢的函数。任何帮助或建议将不胜感激。谢谢:)

# My real text is in german, but since Englisch is more frequent I use "en_core_web_sm" here
import spacy
en_core = spacy.load('en_core_web_sm')

# Create DataFrame
pos_tweets = [('I love this car', 'positive'), ('This view is amazing', 'positive'), ('I feel great this morning', 'positive'), ('I am so excited about the concert', 'positive'), ('He is my best friend', 'positive')]
df = pd.DataFrame(pos_tweets)
df.columns = ["tweet","class"]

# Normalization
df['tweet'] = [entry.lower() for entry in df['tweet']]
# Tokenization
df["tokenized"] = [w.split() for w in df["tweet"]]

# Lemmatization
# This is where I struggle. I can't get together the English Model en_core, lemma_ and stuff :(
df["lemmatized"] = df['tokenized'].apply(lambda x: [en_core(y.lemma_) for y in x])

最佳答案

您需要在文本而不是标记上运行它。

df["lemmatized"] = df['tweet'].apply(lambda x: " ".join([y.lemma_ for y in en_core(x)]))

在这里,x 将是 tweet 列中的一个句子/文本,en_core(x) 将从中创建一个文档,和 y 将代表每个标记,其中 y.lemma_ 产生词引理。 "".join(...) 会将找到的所有 lemms 连接到一个以空格分隔的字符串中。

关于python - 使用 spacy 对 Pandas Dataframe 中的一列已解析的 html 文本进行词形还原,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62712963/

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