python中数据用折线图表示_用python处理文本数据

用python处理文本数据

af03999fd57443ffbceb62bd3b3cf23a.png

Q:这篇文章主要讲什么?

A:这篇文章主要讨论如何用python来做一些简单的文本处理——文本相似度比较。

谈起python的自然语言处理,肯定会让人想起NLTK。不过上面这两个任务并不需要NLTK这个库,只是用到了gensim。由于涉及中文,所以还用到了jieba来做中文分词。

Q:Gensim是什么东西?

A:首先说说gensim是个怎样的python库吧。

由于这篇笔记只记录最简单的用法,所以gensim更详细的介绍,更强大的功能请到官网阅读文档:gensim官网。不懂英文?赶紧去补啊!

74282ec4e868bf9365b546c2d7477c80.png

gensim

Gensim is a free Python library designed to automatically extract semantictopics from documents, as efficiently (computer-wise) and painlessly (human-wise) as possible.

简单来说,gensim的主要功能有把文本转为向量(scikit-learn也能做到),抽取文本中的关键词(jieba也能做到),比较两个文本的相似度,甚至是计算一个查询(本质也是一个文本)与一个文档集合中所有文档的关联程度(这个似乎只有gensim能做,sklearn和jieba都不能)。更强大的是,gensim库实现了word2vec算法(其实我目前不懂这个算法的原理)!。

gensim有三个主要模块——

  • corpora:将文本转为向量,提供存储文本矩阵的方法。这里生产的向量形式是最基本的,族简单的,仅仅是为文档建立词典,然后计数文档中每个词出现的次数。
  • models:将corpora生产的简单向量转化为其他各种不同的向量。可以选择的向量模型有TFIDF, LSI, RP, LDA, HDP等。用户可以先用corpora模块把文本转为简单向量,再用models模块得到自己需要的向量形式。
  • similarites:提供计算文本相似度方法的模块。

gensim其他更强大的功能还没列出,所以想要深入学习就得去官网查阅文档了。

Q:如何使用gensim来计算文本相似度?

A:计算一个查询(字符串)与文档集中所有文档的相似度是搜索引擎的核心功能模块之一。gensim计算文本相似度的的套路就是先用copora模块把文档转为简单的稀疏矩阵;然后用models模块得到符合需要的向量模型;最后用similarities模块计算相似度。下面用一个案例来说明怎样计算文本相似度。

假设现在有一个八个文档组成的文档集:

texts = [    '什么是股票?',    '股票是个什么玩意?',    '新手怎样入门炒股?',    '现在股市的风险大吗?',    'python的自然语言处理',    'gensim的主要功能有把文本转为向量',    '提供存储文本矩阵的方法',    '这篇文章主要讨论如何用python来做一些简单的文本处理']

由于文本转向量算法的原理是统计文本中每个单词出现的个数,所以我们还要把文档集里的每个文档切词,也就是说把一个文档编程一个单词列表(或者数组,或者任何数据容器iterable)。西方语言由于先天就用空格把词分开,而类似中文的东方语言则需要特定的分词模块。一个常用的中文分词模块是jieba分词——可以分词、可以做词性标注、可以抽取关键字的分词模块。详见官方文档(当然是中文的)。

docs = [jieba.lcut_for_search(i) for i in texts] #返回一个包含着很多单词列表的列表。In [4]: print docs[[u'什么', u'是', u'股票', u'?'], [u'股票', u'是', u'个', u'什么', u'玩意', u'?'], [u'新手', u'怎样', u'入门', u'炒股', u'?'], [u'现在', u'股市', u'的', u'风险', u'大', u'吗', u'?'], [u'python', u'的', u'自然', u'语言', u'自然语言', u'处理'], [u'gensim', u'的', u'主要', u'功能', u'有', u'把', u'文本', u'转为', u'向量'], [u'提供', u'存储', u'文本', u'矩阵', u'的', u'方法'], [u'这', u'文章', u'篇文章', u'主要', u'讨论', u'如何', u'用', u'python', u'来', u'做', u'一些', u'简单', u'的', u'文本', u'本处', u'处理', u'文本处理']]#原谅我的机器在打印整个列表时,所有中文会变成unicode编码

下一步是构建文档集(单词列表集)的词典,然后利用词典来用向量表示文档

In [10]: dic = corpora.Dictionary(docs)In [11]: print dic  #这个词典给文档集中每个单词编号Dictionary(45 unique tokens: [u'风险', u'本处', u'的', u'处理', u'什么']...)In [12]: corpus = [dic.doc2bow(i) for i in docs]In [13]: print corpus [[(0, 1), (1, 1), (2, 1), (3, 1)], [(0, 1), (1, 1), (2, 1), (3, 1), (4, 1), (5, 1)], [(3, 1), (6, 1), (7, 1), (8, 1), (9, 1)], [(3, 1), (10, 1), (11, 1), (12, 1), (13, 1), (14, 1), (15, 1)], [(12, 1), (16, 1), (17, 1), (18, 1), (19, 1), (20, 1)], [(12, 1), (21, 1), (22, 1), (23, 1), (24, 1), (25, 1), (26, 1), (27, 1), (28, 1)], [(12, 1), (25, 1), (29, 1), (30, 1), (31, 1), (32, 1)], [(12, 1), (16, 1), (17, 1), (24, 1), (25, 1), (33, 1), (34, 1), (35, 1), (36, 1), (37, 1), (38, 1), (39, 1), (40, 1), (41, 1), (42, 1), (43, 1), (44, 1)]]#这是稀疏矩阵的一种形式,每个列表的每个括号表示(词编号,词的出现次数)

这样一来,文本就转换成矩阵了。不过这个矩阵的向量模型非常简单,我们要用一个高级一点的LSI(潜语义分析)向量模型来做相似度计算。应用models模块的可以做到向量模型的转换。

In [14]: lsi = models.LsiModel(corpus, id2word=dic, num_topics=2)

向量模型转换完成,下面开始进行计算相似度的工作。为了方便和明显,我们计算一下“股票”这个词和“文本”这两个查询与文档集中八个文档的相似度。如果没有意外,按照我们的直觉,我们会看到“股票”这个查询和文档集中前四个文档比较相似,“文本”这个查询和文档集中后四个文档比较相似。

In [21]: qurey1 = "股票"      #首先把这两个查询也变成向量    ...: qurey2 = '文本'    ...: vec_query1 = dic.doc2bow([qurey1])    ...: vec_query2 = dic.doc2bow([qurey2])In [22]: index = similarities.MatrixSimilarity(lsi[corpus])#然后建立索引(估计是倒排词表,下面的就不怎么懂了)In [23]: sims1 = index[lsi[vec_query1]]    ...: sims2 = index[lsi[vec_query2]]#得到了查询语句与哥哥文档的相似度In [24]: sims_result1 = sorted(enumerate(sims1), key=lambda item: -item[1])    ...: sims_result2 = sorted(enumerate(sims2), key=lambda item: -item[1])#给结果排一下序    In [25]: print sims_result1[(1, 0.99990207), (0, 0.99984658), (2, 0.99941468), (3, 0.93057805), (6, 0.31655648), (5, 0.27374423), (4, 0.12518336), (7, -0.11772308)]In [27]: print sims_result2[(4, 0.99776512), (7, 0.98443955), (5, 0.97619325), (6, 0.96549642), (3, 0.4200055), (2, 0.092727646), (0, 0.076089963), (1, 0.07257086)]

很明显的看到“股票”这个查询和文档集中前四个文档比较相似,“文本”这个查询和文档集中后四个文档比较相似,这也是符合我们的常识的。

完整代码:

#coding: utf-8import sys, jiebafrom gensim import corpora, models, similaritiesreload(sys)sys.setdefaultencoding('utf8')texts = [    '什么是股票?',    '股票是个什么玩意?',    '新手怎样入门炒股?',    '现在股市的风险大吗?',    'python的自然语言处理',    'gensim的主要功能有把文本转为向量',    '提供存储文本矩阵的方法',    '这篇文章主要讨论如何用python来做一些简单的文本处理']docs = [jieba.lcut_for_search(i) for i in texts]dic = corpora.Dictionary(docs)corpus = [dic.doc2bow(i) for i in docs]lsi = models.LsiModel(corpus, id2word=dic, num_topics=2)qurey1 = "股票"qurey2 = '文本'vec_query1 = dic.doc2bow([qurey1])vec_query2 = dic.doc2bow([qurey2])index = similarities.MatrixSimilarity(lsi[corpus])sims1 = index[lsi[vec_query1]]sims2 = index[lsi[vec_query2]]sims_result1 = sorted(enumerate(sims1), key=lambda item: -item[1])sims_result2 = sorted(enumerate(sims2), key=lambda item: -item[1])print sims_result1print sims_result2

由于作者对于文本处理和gensim的原理还不太懂,如有不当之处,欢迎高手指点

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/298571.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

.Net Core下使用KeyDB高可用缓存集群

前言提到缓存,首先会想到Redis,它是目前最流行的开源内存键值存储服务。使用单个Redis实例进行缓存非常简单,如果创建高可用集群,则需要一个主节点、两个从节点和多个监视主节点的哨兵节点:哨兵节点监控主节点的状态,一…

超赞!世界10个著名悖论的最终解答来了!

全世界只有3.14 % 的人关注了爆炸吧知识今天小编看到一篇作者Das对十大悖论的个人理解,觉得挺有意思,现在便分享给模友们看看,你们的想法是怎样的呢?电车难题引用:“电车难题”是伦理学领域最为知名的思想实验之一&…

设置计算机网络密码怎么设置路由器,如何在计算机上设置路由器密码?

问: 如何在计算机上设置路由器密码?A: 在计算机浏览器中,输入路由器的管理地址,打开登录页面,输入登录密码,然后进入设置页面.然后打开无线设置或Wi-Fi设置选项,您可以设置无线密码(wifi密码). 打开此选项可…

hive sql 怎么实现循环_不出办公室就能无水造纸?让废纸“秒循环再生”怎么实现的...

废纸变为再生纸,不出办公室就能循环利用起来,既节省大量木材,还不消耗一滴水……第三届进博会上,首次参展的打印巨头爱普生带来其全球首创的“干纤维纸张循环系统”,环保效果令人赞叹,吸引大批观众前来围观…

两头编程,测试中间

最近在做一些开发测试代码的工作,就是为了测试中间业务程序,前头调用程序,后头写挡板程序,说白了就是链路调用,因为复杂度在中间的业务程序,所以前后两端的程序应相对简单。这里就有一个问题:技…

Win32 窗口篇(3)

1.11 如何显示或隐藏窗口的标题栏 使用ModifyStyle方法改变参数来更改窗体样式 void CDemoDlg::OnTest1() {//删除标题栏风格ModifyStyle(WS_CAPTION, 0, SWP_FRAMECHANGED); }void CDemoDlg::OnTest2() {//添加标题栏风格ModifyStyle(0, WS_CAPTION, SWP_FRAMECHANGED); …

linux 消息队列_Linux进程间通信第六讲 标准IPC之消息队列

来源CSDN:CSDN-专业IT技术社区-登录​blog.csdn.net一、概念和原理消息队列是另一种标准IPC,当然也大概遵循大部分标准消息队列,它是存放消息(数据)的队列,而队列是先进先出的线性数据结构换句话说,我们就是利用这个数据结构 进行进程间的通信消息队列允许多个进程同…

15个只有数学老师懂的泪流满面瞬间

全世界只有3.14 % 的人关注了爆炸吧知识「1」大题算了半天,就是跟标准答案对不上「2」一次令人期待的公开课啊啊——啊...「3」这就是传说中美好的协同教研「4」在网上下了一堆 PPT 准备拼到一起「5」预测高考题「6」临下课了还有三道大题没评讲「7」当我以为我已经…

matlab绘制二元一次函数图像_【八上数学】 一次函数必考知识点(下)

【八上数学】《一次函数》必考知识点(中)【八上数学】《函数、一次函数》必考知识点(上)写在前面本讲,我们重点研究一次函数与一元一次方程,不等式,二元一次方程组的问题,帮助同学们解决一些典型问题.一、一次函数与二…

计算机能代替纸笔英语作文,电脑能代替纸笔吗英语作文

电脑能代替纸笔吗英语作文在现实生活或工作学习中,说到作文,大家肯定都不陌生吧,作文可分为小学作文、中学作文、大学作文(论文)。作文的注意事项有许多,你确定会写吗?以下是小编为大家整理的电脑能代替纸笔吗英语作文…

《WinForm开发系列之高级篇》Item2 TCP异步传输

1.AsySocket.cs 代码 publicclassAsySocket {#region私有字段privateSocket mSocket null;privatestringmID "";#endregion#region构造函数publicAsySocket(string_LocalIP, int_LocalPort) { try{ mSocket newSocket(AddressFamily.InterNetwork, SocketType.Stream…

C# params的用法详解

为了将方法声明为可以接受可变数量参数的方法,我们可以使用params关键字来声明数组,要求:(1)在方法声明中的 params 关键字之后不允许任何其他参数,并且在方法声明中只允许一个 params 关键字。(2)该参数必须标识一个一维数组,但类…

spring 单例 获取多例的位_Spring系列第6篇:玩转bean scope,避免跳坑里!

公众号关注“程序员二哥”,设为‘星标’,带你学习更多的知识。本文内容 详细介绍5中bean的sope及使用注意点自定义作用域的实现应用中,有时候我们需要一个对象在整个应用中只有一个,有些对象希望每次使用的时候都重新创建一个&…

女生的拳头有多厉害?

1 天下武功唯快不破2 狗子:没想到我有这种天赋3 哈哈哈还是你社会啊4 女生的拳头有多厉害??5 怎么解开的?6 心中有海,脚下有沙,这就是马尔代夫7 你的人生概括

与ln的指数转化公式_高考数学48条秒杀型公式与方法

点上方蓝字,关注“云学冠学习资讯”有助于提高成绩哦!除了课本上的常规公式之外,掌握一些必备的秒杀型公式能够帮你在考试的时候节省大量的时间,师姐这次的分享就是48条秒杀公式,直接往下看!1.适用条件&…

在C#2.0中使用Nullable可空类型

在C#1.x的版本中,一个值类型变量是不可以被赋予null值的,否则会产生异常。在C#2.0中,微软提供了Nullable类型,允许用它定义包含null值(即空值)的数据类型,这对处理数据库中包含可选字段以及很多…

豆瓣9.7,这些舍不得看完的神剧,看一集少一集!我刷了一晚上……

全世界只有3.14 % 的人关注了爆炸吧知识今天给大家介绍一位好朋友——小樱,小樱,作为资深美剧迷英语博主,收藏了很多经典美剧、动画资源,每天还会和大家分享新鲜有趣的英语知识。喜欢看美剧追动画和立志学好英语的小伙伴千万别错过…

C#编码规范

1、连接数据库并返回DataTable View Code public DataTable GetDataByTable() { DataSet dataset new DataSet(); DataTable datatable null; SqlConnection sqlConnection new SqlConnection("Data Source.;Initial CatalogCalamity_Dat…

api中文文档 mws_中英文排版规范化 API

此文章对开放数据接口 API 之「中英文排版规范化 API」进行了功能介绍、使用场景介绍以及调用方法的说明,供用户在使用数据接口时参考之用。 1. 产品功能此次开放了中英文排版规范化在线接口,用于自动中英文排版、标点符号格式化,中英混排格式…

计算机管理无法连接虚拟磁盘服务,虚拟磁盘服务错误怎么操作【图文教程】

虚拟磁盘我们大家都可以看到但实际上是不存在的,虚拟的就是假的。虚拟磁盘是通过将一些网络文件或是内存利用科技手段伪造成磁盘,我们通常称它为虚拟磁盘。虚拟磁盘可以给内存增加容量,可以加快磁盘数据交换,提高计算机运行速度。…