当前位置:
首页 > temp > python入门教程 >
-
利用spaCy对中文文本分词和去除停用词处理
spaCy简介
spaCy语言模型包含了一些强大的文本分析功能,如词性标注和命名实体识别功能。目前spaCy免费支持的语言有:英文、德语、法语、西班牙语、葡萄语、意大利语和荷兰语,其他的语言也在慢慢的增长。对于spaCy处理中文文本(本文选取了《天龙八部》小说来示例)具体实现过程如下:
1、对文本进行分词处理并去除停用词保存成一个txt
首先,在导入spaCy相关模块后,需要加载中文处理包。然后读取小说数据,对天龙八部小说进行nlp处理,既包括:分词、向量化、词性标注、语法解析和命名实体识别,并对小说用符号“/”进行分隔。最后通过is_stop函数判断分词中的词语是否为停用词,去除掉停用词后把结果写入txt文件中,具体代码如下:
import spacy
import pandas as pd
import time
from spacy.lang.zh.stop_words import STOP_WORDS
nlp = spacy.load('zh_core_web_sm')
def fenci_stopwords(data,newdata1):
fenci = []
qc_stopwords =[]
article = pd.read_table(data,encoding="utf-8")
start1 = time.time()
with open(newdata1,'w',encoding='utf-8') as f1:
for i in article["天龙八部"]:#分词
doc = nlp(i)
result1 = '/'.join([t.text for t in doc])
fenci.append(result1)
for j in fenci:#去除停用词
words = nlp.vocab[j]
if words.is_stop == False:
qc_stopwords.append(j)
result2 = '/'.join(qc_stopwords)
f1.write(result2)
end1 = time.time()
return end1-start1
2、提取文本中所有的人物(去重)并输出成另一份txt
在对天龙八部进行分词和去除停用词处理后,利用nlp函数处理后对文本有属性分类,提取出属性为“PERSON”的词语,写入到另外一份txt文件中:
def quchong(data,newdata2):
person = []
start2 = time.time()
article = pd.read_table(data,encoding="utf-8")
with open(newdata2,"w",encoding="utf-8") as f2:
for i in article["天龙八部"]:#分词
doc = nlp(i)
for k in doc.ents:
if k.label_ == "PERSON":
person.append(k.text)
#print(token.text,token.pos_)
rw = list(set(person))
rw = "\n".join(rw)
f2.write(rw)
end2 = time.time()
return end2-start2
通过在PowerShell运行该文件,结果如下:
3、改进方向
(1)从结果看来,文本分词效果会比jieba处理效果逊色一点,分词这部分建议还是用jieba模块。但是spaCy除了分词,其在向量化、词性标注等方面准确度较高。
(2)从时间消耗来看,处理整本小说所花费的时间较长,原因也有可能是代码中涉及到多重for循坏
出 处:https://www.cnblogs.com/Ukiii/p/14597647.html
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数