NLP(八) 创建自然语言处理管道
原文链接:http://www.one2know.cn/nlp8/
- 一条管道可以被看作一个多阶段的数据流系统,其中一个组件的输出被视为另一个组件的输入
- 管道特点:
- 数据始终从一个组件流向另一个组件
- 组件是一个只考虑输入和输出数据的黑盒
- NLP管道应有的功能:
- 采集输入数据
- 对输入数据进行分词
- 识别输入数据中单词的词性
- 从单词中抽取命名实体
- 识别命名实体之间的关系
import nltk
import threading # 轻量级任务的线程库
import queue #可在多线程程序中使用的队列库
import feedparser # RSS源解析库
import uuid # 基于RFC-4122的uuid版本1,3,4,5的生成库
threads = [] # 创建一个空列表来跟踪程序中的所有线程
queues = [queue.Queue(),queue.Queue()] # 创建一个包含两个队列对象的列表
# 第一个队列:存储分词后的句子
# 第二个队列:存储所有标注过词性的单词
def extractWords():
url = 'http://sports.yahoo.com/mlb/rss.xml'
feed = feedparser.parse(url)
for entry in feed['entries'][:5]:
text = entry['title'] # 标题存到text里
if 'ex' in text: # 跳过包含敏感词的标题,有ex存在就不处理了
continue
words = nltk.word_tokenize(text) # 将标题分词
data = {'uuid':uuid.uuid4(),'input':words} # 两个键值对,存储UUID和输入的单词
queues[0].put(data,True) # 将字典放到第一个队列
print(">> {} : {}".format(data['uuid'],text))
# 从第一个队列读取数据,并处理数据,将这些单词的词性保存在第二个队列中
def extractPOS():
while True: # 无限循环,直到第一个队列为空
if queues[0].empty():
break
else:
data = queues[0].get()
words = data['input']
postags = nltk.pos_tag(words)
queues[0].task_done() # 已经处理完毕由此线程获取的条目
# 将标注词性的单词列表存储在第二个队列
queues[1].put({'uuid':data['uuid'],'input':postags},True)
# 从第二个队列读取数据,即处理标注词性后的词,并在屏幕打印命名实体
def extractNE():
while True: # 无限循环,直到第二个队列为空
if queues[1].empty():
break
else:
data = queues[1].get()
postags = data['input']
queues[1].task_done()
# 将postags中的命名实体抽取出来存入chunks中
chunks = nltk.ne_chunk(postags,binary=False)
print(" << {} : ".format(data['uuid']),end='')
for path in chunks:
try:
label = path.label()
print(path,end=', ')
except:
pass
print()
def runProgram():
# 启动该线程,并将该线程放到队列
e = threading.Thread(target=extractWords())
e.start()
threads.append(e)
p = threading.Thread(target=extractPOS())
p.start()
threads.append(p)
n = threading.Thread(target=extractNE())
n.start()
threads.append(n)
# 将在所有工作处理完毕后释放分配给queues资源
queues[0].join()
queues[1].join()
# 遍历线程列表,将当前的线程对象存储在t中
for t in threads:
t.join() # 标记线程的完成,并释放分配给线程的资源
if __name__ == "__main__":
runProgram()
输出:
>> be849c82-41cf-4e98-ac32-9766a199e763 : The Bandwagon: All-Stars, America and more
>> 690c174d-a365-4b8a-8712-abd222f13902 : Cards regain power, look for series win vs. Mariners
>> e75f4270-8922-4eab-b688-69e34e387c6f : Yankees look to continue success against Rays
>> f829392a-3702-45bb-bff8-d35261dfa03b : Recap: STL 5, SEA 2
>> ad953f96-21ac-46ea-979d-78086efb964c : Pirates going for 4-game sweep of Cubs
<< be849c82-41cf-4e98-ac32-9766a199e763 : (GPE America/NNP),
<< 690c174d-a365-4b8a-8712-abd222f13902 :
<< e75f4270-8922-4eab-b688-69e34e387c6f : (ORGANIZATION Yankees/NNS), (PERSON Rays/NNP),
<< f829392a-3702-45bb-bff8-d35261dfa03b : (GPE Recap/NN), (ORGANIZATION SEA/NNP),
<< ad953f96-21ac-46ea-979d-78086efb964c : (GPE Cubs/NNP),
NLP(八) 创建自然语言处理管道的更多相关文章
- linux内核剖析(八)进程间通信之-管道
管道 管道是一种两个进程间进行单向通信的机制. 因为管道传递数据的单向性,管道又称为半双工管道. 管道的这一特点决定了器使用的局限性.管道是Linux支持的最初Unix IPC形式之一,具有以下特点: ...
- 【NLP】基于自然语言处理角度谈谈CRF(二)
基于自然语言处理角度谈谈CRF 作者:白宁超 2016年8月2日21:25:35 [摘要]:条件随机场用于序列标注,数据分割等自然语言处理中,表现出很好的效果.在中文分词.中文人名识别和歧义消解等任务 ...
- socketpair创建双向通信的管道(全双工通信)
Linux下socketpair介绍: socketpair创建了一对无名的套接字描述符(只能在AF_UNIX域中使用),描述符存储于一个二元数组,例如sv[2] .这对套接字可以进行双工通信,每一个 ...
- 使用 Visual Studio Team Services 和 IIS 创建持续集成管道
若要将应用程序开发的生成.测试和部署阶段自动化,可以使用持续集成和部署 (CI/CD) 管道. 本教程介绍如何在 Azure 中使用 Visual Studio Team Services 和 Win ...
- NLP之中文自然语言处理工具库:SnowNLP(情感分析/分词/自动摘要)
一 安装与介绍 1.1 概述 SnowNLP是一个python写的类库,可以方便的处理中文文本内容,是受到了TextBlob的启发而写的,由于现在大部分的自然语言处理库基本都是针对英文的,于是写了一个 ...
- mkfifo - 创建FIFO(命名管道)
SYNOPSIS(总览) mkfifo [options] file... POSIX options(选项): [-m mode] GNU options(选项)(最短格式): [-m mode] ...
- 嵌入式Linux驱动学习之路(八)创建最小的根文件系统
busybox 在配置busybox,在是否选择要静态链接库时,在静态下,busybox中的工具不需要动态链接库,能够直接运行.而用户自己编写的程序如果需要动态链接库,还是依然需要有. 如果是动态链接 ...
- Coursera Deep Learning笔记 序列模型(二)NLP & Word Embeddings(自然语言处理与词嵌入)
参考 1. Word Representation 之前介绍用词汇表表示单词,使用one-hot 向量表示词,缺点:它使每个词孤立起来,使得算法对相关词的泛化能力不强. 从上图可以看出相似的单词分布距 ...
- 【说解】在shell中通过mkfifo创建命名管道来控制多个进程并发执行
背景: 工作中有两个异地机房需要传数据,数据全名很规范,在某个目录下命名为统一的前缀加上编号.如/path/from/file.{1..100}.而机房间的专线对单个scp进程的传输速度是有限制的,比 ...
随机推荐
- 【Android Studio】提示代码忽略大小写
在 Preference... 中找到如下,设置 Case sensitive completion 为 None 即可,如下图: PS: 该截图是 Intellij IDEA (Android St ...
- SpringBoot RabbitMQ 整合使用
 ### 前提 上次写了篇文章,[<SpringBoot ...
- C#中属性的解析
一.域的概念 C#中域是指成员变量和方法,在OOP编程中(面向对象编程)我们要求用户只知道类是干什么的,而不许知道如何完成的,或者说不允许访问类的内部,对于有必要在类外可见的域,我们用属性来表达,所以 ...
- SQLServer2000同步复制技术实现步骤
SQLServer2000同步复制技术实现步骤 一. 预备工作 1.发布服务器,订阅服务器都创建一个同名的windows用户,并设置相同的密码,做为发布快照文件夹的有效访问用户 --管理工具 --计算 ...
- Spring的依赖注入和管理Bean
采用Spring管理Bean和依赖注入 1.实例化spring容器 和 从容器获取Bean对象 实例化Spring容器常用的两种方式: 方法一: 在类路径下寻找配置文件来实例化容器 [推荐使用] Ap ...
- 用python实现九九乘法表输出-两种方法
2019-08-05 思考过程:九九乘法表需要两层循环,暂且称之为内循环和外循环,因此需要写双层循环来实现. 循环有for和while两种方式. for循环的实现 for i in range(1,1 ...
- Mybatis获取代理对象
mybatis-config.xml里标签可以放置多个environment,这里可以切换test和develop数据源 databaseIdProvider提供多种数据库,在xml映射文件里选择da ...
- JAVA jobs
Java岗位1, SpringMVC, spring, mybaits2, 高并发编程3, mysql或者oracle SQL调优及函数,存储过程,JOB调度
- Spark1——介绍
1.Spark是什么 Spark是一个用来实现快速而通用的集群计算的平台. 2.Spark是一个大一统的软件栈 Spark项目包含多个紧密集成的组件.首先Spark的核心是一个对由很多计算任务组成的. ...
- exe4j打包--exe转安装包
前面一篇已经详细的说明了打包成exe的步骤了,下面谈谈exe如何压缩成安装文件.这里用到之前的另外一个软件,具体软件看这篇文章 exe4j打包成exe 打开inno 编辑器 打开软件后我们选择 用[脚 ...