斯坦福开源Python库StanfordNLP,可处理53种人类语言

2023-10-28 01:20

本文主要是介绍斯坦福开源Python库StanfordNLP,可处理53种人类语言,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

近期,斯坦福大学自然语言处理小组开发了一个Python库StanfordNLP,用于解决许多常见的自然语言处理问题,可以处理多达53种人类语言模型,便于数据科学家和Python开发人员使用。

语言

StanfordNLP提供了针对53种人类语言的预训练的深度学习模型,并使用PyTorch作为其机器学习的入门。

每种语言都有一个treebank,它是一个巨大的文本数据集,为语法结构/语义内容进行了可靠的注释。对于某些语言,库中提供了不只一个treebank。

如果你想要拥有自己的带注释的语料库(这种情况并不常见!),那么你可以基于语料库训练一个新的模型。

\"image\"

解析这句话!

范围

这个库提供下列服务:

  • 将给定的文本分成句子和单词(符号化)。符号化是指将一个文本(“The day of the groundhog attracts attention”)转换成七个单词的序列(“The”,“day”,“of”,“The”,“groundhog”,“caught”,“attention”)。

  • 为给定的单词指定一个基本形式(词形归并)。词形归并工具会将“attraction”、“attractive”和“attractive”与同一个词形(例如“attract”)联系起来。

  • 在一个句子中,把单词和词性联系起来。所以“day”是名词,“attract”是动词。

  • 单词有形态特征,如单数或现在进行时。这个库也会提供帮助。

  • 它还可以产生句子的句法结构。

  • 最后,StanfordNLP可以与名气更大、应用范围更广泛的Stanford CoreNLP进行整合。

在这篇文章中,我们将探讨符号化、词性和形态学特征。

\"image\"

StanfordNLP管道

管道

Vish (Ishaya) Abrams在文章中很好地解释了机器学习中的管道。为了这个目的,我们可以将库看作是一组组件的序列,这些组件的执行方式是,一个组件的输出是另一个组件的输入(一部分)。这种设计允许替换管道中的一个专用组件,同时保留其余组件。

考虑到文本在管道中流动,那么文本会经过不同步骤的处理。

在StanfordNLP中,管道与语言和treebank相关联。详细信息请看这里(https://stanfordnlp.github.io/stanfordnlp/pipeline.html),但你现在还不需要它们。StanfordNLP管道用于模型评估,而不是模型训练。

安装

在进行其他步骤之前,我们需要先安装这个库。Python 3.6或之后的版本可用。正如开发人员所解释的,安装StanfordNLP最简单的方法是使用pip:

pip install stanfordnlp

之后,下载我们想要使用的语言,例如:

import stanfordnlp
#You only download languages once
#Each language requires more that 1GB of disk space
#It takes time… have a coffee!
stanfordnlp.download(‘en’)
stanfordnlp.download(‘es’)
stanfordnlp.download(‘fr’)

接下来是在哪里存储下载的语言包。这一步我们建议使用缺省值。下载完成后,你可以检查每种语言都有一个对应的文件夹,其中保存了许多PyTorch模型,这些模型将用于我们将要介绍的各种NLP任务。

词性标注及其有用的原因

词性标注是复杂的NLP活动中的一项基本任务。想一下文本分类、情感分析或信息索引和检索。建立文本的基本语法结构为进一步的文本处理奠定了基础。

解析和标记一个句子

我们以下面的法语为例:

Si ce discours semble trop long pour être lu en une fois, on le pourra distinguer en six parties (René Descartes, Discourse on the method)

中文大意:如果这句话对于你来说太长了,不能一次读完,你可以把它分为六部分(雷内·笛卡尔,关于方法的言论)

但是别担心,我们会把这句话变得简短很多!让我们来分析笛卡尔的句子,评估一下每个单词在其中的作用。符号化和词性标注开始发挥作用。

import stanfordnlp# English is the default language, so you# just invoke stanfordnlp.Pipeline()# For Spanish you would call # stanfordnlp.Pipeline(lang=\u0026quot;es\u0026quot;, treebank=\u0026quot;es_ancora\u0026quot;)# This sets up a neural pipeline in Frenchnlp = stanfordnlp.Pipeline(lang=\u0026quot;fr\u0026quot;, treebank=\u0026quot;fr_gsd\u0026quot;)# a document is made of sentencesdoc = nlp(\u0026quot;Si ce discours semble trop long pour être lu en une fois, on le pourra distinguer en six parties\u0026quot;)# we pick our first and only sentenceonly_sentence = doc.sentences[0]# a sentence is made of words. # Each word is tagged with a part of speech (POS)# Good pythonic guys prefer list comprehensions over for loops!print(\u0026quot; \u0026quot;. join([\u0026quot;{} ({})\u0026quot;.format(word.text, word.upos) for word in only_sentence.words]))

在一些信息量丰富的消息之后,我们得到单词列表,每个单词都附在其相应的词性上:

Si (SCONJ) ce (DET) discours (NOUN) semble (VERB) trop (ADV) long (ADJ) pour (ADP) être (AUX) lu (VERB) en (ADP) une (DET) fois (NOUN) , (PUNCT) on (PRON) le (PRON) pourra (VERB) distinguer (VERB) en (ADP) six (NUM) parties (NOUN)

以上这些可以告诉我们,six是一个数字决定因素,而parties是一个名词。请注意,当lu被标识为动词时, être被标记为助动词。

StanfordNLP利用了语音集的通用部分,它的优点是适用于多种语言。但是,只要有treebank的支持,属性pos也会使用和显示语言的特定词性。其他NLP库(如spacy)也使用通用的和某种语言特有的语音集部分。

\"image\"

Chomsky的玩笑

处理一词多义

现在我们用这个库开个小玩笑。我们想知道这个英语句子的词性:

I book the book while you stand by the stand

在同一个句子中,不仅book和stand有两种不同的含义。它们也充当动词和名词。运行这句话的类似代码,我们会得到:

I (PRON) book (VERB) the (DET) book (NOUN) while (SCONJ) you (PRON) stand (VERB) by (ADP) the (DET) stand (NOUN)

我用这个简单的例子引起读者的注意力,它表明词性标记已经超出了在字典中查找单词,词的句法结构决定了词性。这就是伴随着库出现的学习模型在显示其作用。

形态学特征

除了通用形式和特定于语言形式的词性外,这个库中的单词分类里还带有单词的形态特征(请注意文档中可能出现的一个故障,该属性在文档中被称为ufeats)。

我们运行以下代码:

en_nlp = stanfordnlp.Pipeline()doc = en_nlp(\u0026quot;My taylor is drunk\u0026quot;) only_sentence = doc.sentences[0]print(\u0026quot; \u0026quot;. join([\u0026quot;{} ({} - {})\u0026quot;.format(word.text, word.upos, word.feats) for word in only_sentence.words]))

我们得到:

My (PRON - Number=Sing|Person=1|Poss=Yes|PronType=Prs)taylor (NOUN - Number=Sing) is (AUX - Mood=Ind|Number=Sing|Person=3|Tense=Pres|VerbForm=Fin) drunk (ADJ - Degree=Pos)

每个词都有自己的特点,但不只是名词和动词。要理解上述内容,可以查找此索引。例如,Degree=Pos意味着positive,一级。注意,drunk被定义为形容词,不是动词。

关闭

我想今天这些就够了。我们喜欢库,觉得使用它很舒服。当文档不足时,你可以查看源代码来帮助你理解。接下来,我们将完成对StanfordNLP提供的其他功能的理解。

更多信息:https://gitconnected.com/learn/python

原文链接:https://levelup.gitconnected.com/first-look-at-stanfordnlp-2b7d43190957

这篇关于斯坦福开源Python库StanfordNLP,可处理53种人类语言的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/289702

相关文章

基于Python打造一个可视化FTP服务器

《基于Python打造一个可视化FTP服务器》在日常办公和团队协作中,文件共享是一个不可或缺的需求,所以本文将使用Python+Tkinter+pyftpdlib开发一款可视化FTP服务器,有需要的小... 目录1. 概述2. 功能介绍3. 如何使用4. 代码解析5. 运行效果6.相关源码7. 总结与展望1

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Python Websockets库的使用指南

《PythonWebsockets库的使用指南》pythonwebsockets库是一个用于创建WebSocket服务器和客户端的Python库,它提供了一种简单的方式来实现实时通信,支持异步和同步... 目录一、WebSocket 简介二、python 的 websockets 库安装三、完整代码示例1.

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.