前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >适用于NLP自然语言处理的Python:使用Facebook FastText库

适用于NLP自然语言处理的Python:使用Facebook FastText库

原创
作者头像
拓端
修改于 2020-09-27 02:14:53
修改于 2020-09-27 02:14:53
1K00
代码可运行
举报
文章被收录于专栏:拓端tecdat拓端tecdat
运行总次数:0
代码可运行

原文链接:http://tecdat.cn/?p=8572

在本文中,我们将研究FastText,它是用于单词嵌入和文本分类的另一个极其有用的模块。

在本文中,我们将简要探讨FastText库。本文分为两个部分。在第一部分中,我们将看到FastText库如何创建向量表示形式,该向量表示形式可用于查找单词之间的语义相似性。在第二部分中,我们将看到FastText库在文本分类中的应用。

语义相似性的FastText

FastText支持词袋和Skip-Gram模型。在本文中,我们将实现skip-gram模型,由于这些主题非常相似,因此我们选择这些主题以拥有大量数据来创建语料库。您可以根据需要添加更多类似性质的主题。

第一步,我们需要导入所需的库。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ pip install wikipedia

导入库

以下脚本将所需的库导入我们的应用程序:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
from keras.preprocessing.text import Tokenizerfrom gensim.models.fasttext import FastTextimport numpy as npimport matplotlib.pyplot as pltimport nltkfrom string import punctuationfrom nltk.corpus import stopwordsfrom nltk.tokenize import word_tokenizefrom nltk.stem import WordNetLemmatizerfrom nltk.tokenize import sent_tokenizefrom nltk import WordPunctTokenizerimport wikipediaimport nltknltk.download('punkt')nltk.download('wordnet')nltk.download('stopwords')en_stop = set(nltk.corpus.stopwords.words('english'))%matplotlib inline
对于单词表示和语义相似性,我们可以将Gensim模型用于FastText。

维基百科文章

在这一步中,我们将抓取所需的Wikipedia文章。看下面的脚本:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
artificial_intelligence = wikipedia.page("Artificial Intelligence").contentmachine_learning = wikipedia.page("Machine Learning").contentdeep_learning = wikipedia.page("Deep Learning").contentneural_network = wikipedia.page("Neural Network").contentartificial_intelligence = sent_tokenize(artificial_intelligence)machine_learning = sent_tokenize(machine_learning)deep_learning = sent_tokenize(deep_learning)neural_network = sent_tokenize(neural_network)artificial_intelligence.extend(machine_learning)artificial_intelligence.extend(deep_learning)artificial_intelligence.extend(neural_network)

要抓取Wikipedia页面,我们可以使用模块中的page方法wikipedia。您要剪贴的页面名称作为参数传递给page方法。该方法返回WikipediaPage对象,然后您可以使用该对象通过content属性来检索页面内容,如上面的脚本所示。

然后使用该sent_tokenize方法将来自四个Wikipedia页面的抓取的内容标记为句子。该sent_tokenize方法返回句子列表。四个页面的句子分别标记。最后,通过该extend方法将四篇文章中的句子连接在一起。

数据预处理

下一步是通过删除标点符号和数字来清除文本数据。

preprocess_text如下定义的功能执行预处理任务。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import refrom nltk.stem import WordNetLemmatizerstemmer = WordNetLemmatizer()def preprocess_text(document):        preprocessed_text = ' '.join(tokens)        return preprocessed_text

让我们看看我们的函数是否通过预处理一个伪句子来执行所需的任务:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sent = preprocess_text("Artificial intelligence, is the most advanced technology of the present era")print(sent)

预处理语句如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
artificial intelligence advanced technology present

您会看到标点符号和停用词已被删除。

创建单词表示

我们已经对语料库进行了预处理。现在是时候使用FastText创建单词表示形式了。首先让我们为FastText模型定义超参数:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
embedding_size = 60window_size = 40min_word = 5down_sampling = 1e-2

embedding_size是嵌入向量的大小。

下一个超参数是min_word,它指定语料库中单词生成的最小频率。最后,最频繁出现的单词将通过down_sampling属性指定的数字进行下采样。

现在让我们FastText为单词表示创建模型。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
%%timeft_model = FastText(word_tokenized_corpus,                      size=embedding_size,                      window=window_size,                      min_count=min_word,                      sample=down_sampling,                      sg=1,                      iter=100)

sg参数定义了我们要创建模型的类型。值为1表示我们要创建跳跃语法模型。零指定单词袋模型,这也是默认值。

执行上面的脚本。运行可能需要一些时间。在我的机器上,上述代码运行的时间统计信息如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
CPU times: user 1min 45s, sys: 434 ms, total: 1min 45sWall time: 57.2 s
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 print(ft_model.wv['artificial'])

这是输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[-3.7653010e-02 -4.5558015e-01  3.2035065e-01 -1.5289043e-01  4.0645871e-02 -1.8946664e-01  7.0426887e-01  2.8806925e-01 -1.8166199e-01  1.7566417e-01  1.1522485e-01 -3.6525184e-01 -6.4378887e-01 -1.6650060e-01  7.4625671e-01 -4.8166099e-01  2.0884991e-01  1.8067230e-01 -6.2647951e-01  2.7614883e-01 -3.6478557e-02  1.4782918e-02 -3.3124462e-01  1.9372456e-01  4.3028224e-02 -8.2326338e-02  1.0356739e-01  4.0792203e-01 -2.0596240e-02 -3.5974573e-02  9.9928051e-02  1.7191900e-01 -2.1196717e-01  6.4424530e-02 -4.4705093e-02  9.7391091e-02 -2.8846195e-01  8.8607501e-03  1.6520244e-01 -3.6626378e-01 -6.2017748e-04 -1.5083785e-01 -1.7499258e-01  7.1994811e-02 -1.9868813e-01 -3.1733567e-01  1.9832127e-01  1.2799081e-01 -7.6522082e-01  5.2335665e-02 -4.5766738e-01 -2.7947658e-01  3.7890410e-03 -3.8761377e-01 -9.3001537e-02 -1.7128626e-01 -1.2923178e-01  3.9627206e-01 -3.6673656e-01  2.2755004e-01]

 现在让我们找到“人造”,“智能”,“机器”,“网络”,“经常出现”,“深度”这五个最相似的词。您可以选择任意数量的单词。以下脚本将打印指定的单词以及5个最相似的单词。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
for k,v in semantically_similar_words.items():    print(k+":"+str(v))

输出如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
artificial:['intelligence', 'inspired', 'book', 'academic', 'biological']intelligence:['artificial', 'human', 'people', 'intelligent', 'general']machine:['ethic', 'learning', 'concerned', 'argument', 'intelligence']network:['neural', 'forward', 'deep', 'backpropagation', 'hidden']recurrent:['rnns', 'short', 'schmidhuber', 'shown', 'feedforward']deep:['convolutional', 'speech', 'network', 'generative', 'neural']

我们还可以找到任意两个单词的向量之间的余弦相似度,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
print(ft_model.wv.similarity(w1='artificial', w2='intelligence'))

输出显示值为“ 0.7481”。该值可以介于0到1之间。更高的值表示更高的相似度。

可视化单词相似性

尽管模型中的每个单词都表示为60维向量,但是我们可以使用主成分分析技术来找到两个主成分。然后可以使用两个主要成分在二维空间中绘制单词。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
print(all_similar_words)print(type(all_similar_words))print(len(all_similar_words))

字典中的每个键都是一个单词。相应的值是所有语义相似的单词的列表。由于我们在“人工”,“智能”,“机器”,“网络”,“经常性”,“深度”这6个词的列表中找到了前5个最相似的词,因此您会发现其中有30个词该all_similar_words列表。

接下来,我们必须找到所有这30个单词的单词向量,然后使用PCA将单词向量的维数从60减小到2。然后可以使用plt方法,该matplotlib.pyplot方法是绘制单词的方法的别名在二维向量空间上。

执行以下脚本以可视化单词:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
word_vectors = ft_model.wv[all_similar_words]for word_names, x, y in zip(word_names, p_comps[:, 0], p_comps[:, 1]):    plt.annotate(word_names, xy=(x+0.06, y+0.03), xytext=(0, 0), textcoords='offset points')

上面脚本的输出如下所示:

可以看到在文本中经常一起出现的单词在二维平面中也彼此靠近。

用于文本分类的FastText

文本分类是指根据文本的内容将文本数据分类为预定义的类别。情感分析,垃圾邮件检测和标签检测是一些用于文本分类的用例的最常见示例。

数据集

数据集包含多个文件,但我们仅对该yelp_review.csv文件感兴趣。该文件包含有关不同业务(包括餐馆,酒吧,牙医,医生,美容院等)的520万条评论。但是,由于内存限制,我们将仅使用前50,000条记录来训练我们的模型。如果需要,可以尝试更多记录。

让我们导入所需的库并加载数据集:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import pandas as pdimport numpy as npyelp_reviews = pd.read_csv("/content/drive/My Drive/Colab Datasets/yelp_review_short.csv")

在上面的脚本中,我们yelp_review_short.csv使用pd.read_csv函数加载了包含50,000条评论的文件。

通过将评论的数值转换为分类数值,可以简化我们的问题。这将通过在reviews_score数据集中添加新的列来完成。

最后,数据帧的标题如下所示

安装FastText

下一步是导入FastText模型,可以使用以下wget命令从GitHub存储库中导入该命令,如以下脚本所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
!wget https://github.com/facebookresearch/fastText/archive/v0.1.0.zip

如果您运行上述脚本并看到以下结果,则表明FastText已成功下载:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
--2019-08-16 15:05:05--  https://github.com/facebookresearch/fastText/archive/v0.1.0.zipResolving github.com (github.com)... 140.82.113.4Connecting to github.com (github.com)|140.82.113.4|:443... connected.HTTP request sent, awaiting response... 302 FoundLocation: https://codeload.github.com/facebookresearch/fastText/zip/v0.1.0 [following]--2019-08-16 15:05:05--  https://codeload.github.com/facebookresearch/fastText/zip/v0.1.0Resolving codeload.github.com (codeload.github.com)... 192.30.255.121Connecting to codeload.github.com (codeload.github.com)|192.30.255.121|:443... connected.HTTP request sent, awaiting response... 200 OKLength: unspecified [application/zip]Saving to: ‘v0.1.0.zip’v0.1.0.zip              [ <=>                ]  92.06K  --.-KB/s    in 0.03s2019-08-16 15:05:05 (3.26 MB/s) - ‘v0.1.0.zip’ saved [94267]

下一步是解压缩FastText模块。只需键入以下命令:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
!unzip v0.1.0.zip

接下来,您必须导航到下载FastText的目录,然后执行!make命令以运行C ++二进制文件。执行以下步骤:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cd fastText-0.1.0!make

如果看到以下输出,则表明FastText已成功安装在您的计算机上。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
c++ -pthread -std=c++0x -O3 -funroll-loops -c src/args.ccc++ -pthread -std=c++0x -O3 -funroll-loops -c src/dictionary.ccc++ -pthread -std=c++0x -O3 -funroll-loops -c src/productquantizer.ccc++ -pthread -std=c++0x -O3 -funroll-loops -c src/matrix.ccc++ -pthread -std=c++0x -O3 -funroll-loops -c src/qmatrix.ccc++ -pthread -std=c++0x -O3 -funroll-loops -c src/vector.ccc++ -pthread -std=c++0x -O3 -funroll-loops -c src/model.ccc++ -pthread -std=c++0x -O3 -funroll-loops -c src/utils.ccc++ -pthread -std=c++0x -O3 -funroll-loops -c src/fasttext.ccc++ -pthread -std=c++0x -O3 -funroll-loops args.o dictionary.o productquantizer.o matrix.o qmatrix.o vector.o model.o utils.o fasttext.o src/main.cc -o fasttext

要验证安装,请执行以下命令:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
!./fasttext

您应该看到FastText支持以下命令:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
usage: fasttext <command> <args>The commands supported by FastText are:  supervised              train a supervised classifier  quantize                quantize a model to reduce the memory usage  test                    evaluate a supervised classifier  predict                 predict most likely labels  predict-prob            predict most likely labels with probabilities  skipgram                train a skipgram model  cbow                    train a cbow model  print-word-vectors      print word vectors given a trained model  print-sentence-vectors  print sentence vectors given a trained model  nn                      query for nearest neighbors  analogies               query for analogies

文字分类

在训练FastText模型进行文本分类之前,需要先提及FastText接受特殊格式的数据,具体如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
_label_tag This is sentence 1_label_tag2 This is sentence 2.

如果我们查看我们的数据集,它不是所需的格式。具有积极情绪的文本应如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
__label__positive burgers are very big portions here.

同样,负面评论应如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
__label__negative They do not use organic ingredients, but I thi...

以下脚本从数据集中过滤出reviews_scoretext列,然后__label__在该reviews_score列中的所有值之前添加前缀。类似地,\n\ttext列中的空格替换。最后,更新后的数据帧以的形式写入yelp_reviews_updated.txt

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import pandas as pdfrom io import StringIOimport csvcol = ['reviews_score', 'text']

现在让我们打印更新后的yelp_reviews数据框。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
yelp_reviews.head()

您应该看到以下结果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
reviews_score   text0   __label__positive   Super simple place but amazing nonetheless. It...1   __label__positive   Small unassuming place that changes their menu...2   __label__positive   Lester's is located in a beautiful neighborhoo...3   __label__positive   Love coming here. Yes the place always needs t...4   __label__positive   Had their chocolate almond croissant and it wa...

同样,数据框的尾部如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    reviews_score   text49995   __label__positive   This is an awesome consignment store! They hav...49996   __label__positive   Awesome laid back atmosphere with made-to-orde...49997   __label__positive   Today was my first appointment and I can hones...49998   __label__positive   I love this chic salon. They use the best prod...49999   __label__positive   This place is delicious. All their meats and s...

我们已经将数据集转换为所需的形状。下一步是将我们的数据分为训练集和测试集。80%的数据(即50,000条记录中的前40,000条记录)将用于训练数据,而20%的数据(最后10,000条记录)将用于评估算法的性能。

以下脚本将数据分为训练集和测试集:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
!head -n 40000 "/content/drive/My Drive/Colab Datasets/yelp_reviews_updated.txt" > "/content/drive/My Drive/Colab Datasets/yelp_reviews_train.txt"!tail -n 10000 "/content/drive/My Drive/Colab Datasets/yelp_reviews_updated.txt" > "/content/drive/My Drive/Colab Datasets/yelp_reviews_test.txt"

yelp_reviews_train.txt便会生成包含训练数据的文件。同样,新生成的yelp_reviews_test.txt文件将包含测试数据。

现在是时候训练我们的FastText文本分类算法了。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
%%time!./fasttext supervised -input "/content/drive/My Drive/Colab Datasets/yelp_reviews_train.txt" -output model_yelp_reviews

为了训练算法,我们必须使用supervised命令并将其传递给输入文件。这是上面脚本的输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Read 4M wordsNumber of words:  177864Number of labels: 2Progress: 100.0%  words/sec/thread: 2548017  lr: 0.000000  loss: 0.246120  eta: 0h0mCPU times: user 212 ms, sys: 48.6 ms, total: 261 msWall time: 15.6 s

您可以通过以下!ls命令查看模型:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
!ls

这是输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
args.o             Makefile         quantization-results.shclassification-example.sh  matrix.o         README.mdclassification-results.sh  model.o          srcCONTRIBUTING.md        model_yelp_reviews.bin   tutorialsdictionary.o           model_yelp_reviews.vec   utils.oeval.py            PATENTS          vector.ofasttext           pretrained-vectors.md    wikifil.plfasttext.o         productquantizer.o       word-vector-example.shget-wikimedia.sh       qmatrix.o            yelp_reviews_train.txtLICENSE            quantization-example.sh

可以model_yelp_reviews.bin在上面的文档列表中看到。

最后,可以使用以下test命令测试模型。必须在test命令后指定型号名称和测试文件,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
!./fasttext test model_yelp_reviews.bin "/content/drive/My Drive/Colab Datasets/yelp_reviews_test.txt"

上面脚本的输出如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
N   10000P@1 0.909R@1 0.909Number of examples: 10000

这里P@1是指精度,R@1是指召回率。您可以看到我们的模型达到了0.909的精度和召回率,这相当不错。

现在,让我们尝试清除标点符号和特殊字符的文本,并将其转换为小写字母,以提高文本的一致性。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
!cat "/content/drive/My Drive/Colab Datasets/yelp_reviews_train.txt" | sed -e "s/\([.\!?,’/()]\)/ \1 /g" | tr "[:upper:]" "[:lower:]" > "/content/drive/My Drive/Colab Datasets/yelp_reviews_train_clean.txt"

并且以下脚本清除了测试集:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
"/content/drive/My Drive/Colab Datasets/yelp_reviews_test.txt" | sed -e "s/\([.\!?,’/()]\)/ \1 /g" | tr "[:upper:]" "[:lower:]" > "/content/drive/My Drive/Colab Datasets/yelp_reviews_test_clean.txt"

现在,我们将在清理的训练集上训练模型:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
%%time!./fasttext supervised -input "/content/drive/My Drive/Colab Datasets/yelp_reviews_train_clean.txt" -output model_yelp_reviews

最后,我们将使用在净化训练集上训练的模型对测试集进行预测:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
!./fasttext test model_yelp_reviews.bin "/content/drive/My Drive/Colab Datasets/yelp_reviews_test_clean.txt"

上面脚本的输出如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
N   10000P@1 0.915R@1 0.915Number of examples: 10000

您会看到精度和召回率都有小幅提高。为了进一步改善模型,您可以增加模型的时代和学习率。以下脚本将元数设置为30,将学习率设置为0.5。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
%%time!./fasttext supervised -input "/content/drive/My Drive/Colab Datasets/yelp_reviews_train_clean.txt" -output model_yelp_reviews -epoch 30 -lr 0.5

结论

最近,已证明FastText模型可用于许多数据集上的单词嵌入和文本分类任务。与其他单词嵌入模型相比,它非常易于使用并且闪电般快速。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
【python】教你彻底了解Python中的自然语言处理(NLP)
​​​自然语言处理(Natural Language Processing,简称NLP)是人工智能的一个重要分支,旨在通过计算机理解和生成人类语言。在Python中,有许多强大的库和工具可以用于自然语言处理。本文将深入探讨Python在自然语言处理中的应用,涵盖自然语言处理的基本概念、常用的NLP库、文本预处理、词嵌入与特征提取、文本分类、情感分析、命名实体识别,以及一些实际应用示例。
E绵绵
2025/05/25
220
fastText细节及实践
fastText模型是类似CBOW的三层结构,关于这个结构的介绍,很多博客都讲了,这里我不多赘述,我主要叙述一下其中的部分细节
mathor
2020/06/18
1.3K1
fastText细节及实践
Python 数据科学入门教程:NLTK
欢迎阅读自然语言处理系列教程,使用 Python 的自然语言工具包 NLTK 模块。
ApacheCN_飞龙
2022/12/01
4.6K0
Python 数据科学入门教程:NLTK
Python自然语言处理面试:NLTK、SpaCy与Hugging Face库详解
NLTK、SpaCy与Hugging Face库作为Python自然语言处理(NLP)领域的三大主流工具,其理解和应用能力是面试官评价候选者NLP技术实力的重要标准。本篇博客将深入浅出地探讨Python NLP面试中与NLTK、SpaCy、Hugging Face库相关的常见问题、易错点,以及如何避免这些问题,同时附上代码示例以供参考。
Jimaks
2024/04/19
3950
基于自然语言处理的垃圾短信识别系统
本项目旨在利用自然语言处理(NLP)技术,开发一个高效的垃圾短信识别系统。通过分词、停用词处理、情感分析和机器学习模型,实现对垃圾短信的自动分类和识别,提高短信过滤的准确性和效率。
LucianaiB
2025/01/25
1940
基于自然语言处理的垃圾短信识别系统
Codis 基础3
直接使用 go get -u -d github.com/wandoulabs/codis 来获取codis源码
franket
2022/03/22
6220
NLP自然语言处理002:NLTK中的语料和词汇资源
import nltk 直接获取语料库的所有文本:nltk.corpus.gutenberg.fileids()
李玺
2021/11/22
6840
NLP自然语言处理002:NLTK中的语料和词汇资源
一文概览NLP算法(Python)
NLP是人工智能领域历史较为悠久的领域,但由于语言的复杂性(语言表达多样性/歧义/模糊等等),如今的发展及收效相对缓慢。比尔·盖茨曾说过,"NLP是 AI 皇冠上的明珠。" 在光鲜绚丽的同时,却可望而不可及(...)。
算法进阶
2022/06/02
2.3K0
一文概览NLP算法(Python)
自然语言处理学术速递[7.23]
【1】 Multi-Stream Transformers 标题:多流Transformer
公众号-arXiv每日学术速递
2021/07/27
3060
自然语言处理(NLP)入门指南
授权转载自数据派THU ID:DatapiTHU 作者:Melanie Tosik 翻译:闵黎 校对:丁楠雅 Melanie Tosik目前就职于旅游搜索公司WayBlazer,她的工作内容是通过
大数据文摘
2018/05/24
1.4K0
自然语言处理学术速递[12.6]
【1】 Linear algebra with transformers 标题:带Transformer的线性代数 链接:https://arxiv.org/abs/2112.01898
公众号-arXiv每日学术速递
2021/12/09
6270
【NLP自然语言处理】FastText在文本分类中的智能应用与探索
数据集介绍,本案例烹饪相关的数据集, 它是由facebook AI实验室提供的演示数据集
小言从不摸鱼
2024/12/12
3740
【NLP自然语言处理】FastText在文本分类中的智能应用与探索
Python NLTK 自然语言处理入门与例程
那么 NLP 到底是什么?学习 NLP 能带来什么好处?
Sepmer Fi
2018/02/23
6.3K1
使用Python实现自然语言处理模型
自然语言处理(Natural Language Processing,简称NLP)是人工智能领域的一个重要分支,它涉及计算机与人类自然语言之间的交互。NLP技术可以帮助计算机理解、解释、操纵人类语言,从而实现文本分类、情感分析、机器翻译等任务。在本文中,我们将介绍自然语言处理的基本原理和常见的实现方法,并使用Python来实现这些模型。
Echo_Wish
2024/04/25
2720
Python 高级实战:基于自然语言处理的情感分析系统
在大数据和人工智能迅猛发展的今天,自然语言处理(NLP)作为人工智能的重要分支,已经深入到我们的日常生活和工作中。情感分析作为NLP中的一个重要应用,广泛应用于市场分析、舆情监控和客户反馈等领域。本文将讲述一个基于Python实现的情感分析系统,旨在帮助大家进一步提升在NLP领域的技能。
摸五休二
2024/11/20
2600
GitHub项目:自然语言处理领域的相关干货整理
自然语言处理(NLP)是计算机科学,人工智能,语言学关注计算机和人类(自然)语言之间的相互作用的领域。本文作者为NLP初学者整理了一份庞大的自然语言处理领域的概览。选取的参考文献与资料都侧重于最新的深度学习研究成果。这些资源能为想要深入钻研一个NLP任务的人们提供一个良好的开端。 指代消解 https://github.com/Kyubyong/nlp_tasks#coreference-resolution 论文自动评分 论文:Automatic Text Scoring Using Neural Net
AiTechYun
2018/03/05
2.8K0
Python自然语言处理—提取词干
在英文中同一个词的形式是有多种的,名词的单数复数、动词的现在和过去式等等,所以在处理英文时要考虑词干的抽取问题。这里直接调用Nltk自带的两个词干抽取器
用户7886150
2020/12/28
1.1K0
自然语言处理| NLTK库的详解
自然语言处理(natural language processing)是计算机科学领域与人工智能领域中的一个重要方向。它研究能实现人与计算机之间用自然语言进行有效通信的各种理论和方法。自然语言处理是一门融语言学、计算机科学、数学于一体的科学。
润森
2019/08/29
7K0
自然语言处理| NLTK库的详解
Redis的搭建和Redis的集群搭建
1、Redis的官网:https://redis.io/     Redis的测试网站:http://try.redis.io/
别先生
2018/07/31
1.2K1
Redis的搭建和Redis的集群搭建
NLP 自然语言处理的发展历程
自然语言处理(Natural Language Processing,NLP)是人工智能领域中的一个重要分支,致力于使计算机能够理解、理解和生成自然语言。自然语言处理的发展历程经历了多个阶段,从最早的基于规则的方法到后来的统计学习和深度学习方法。本文将深入探讨自然语言处理的发展历程,结合实例演示,并提供详细的代码解释,同时介绍数据处理的关键步骤。
数字扫地僧
2023/12/18
1.2K0
相关推荐
【python】教你彻底了解Python中的自然语言处理(NLP)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档