`
strayly
  • 浏览: 97436 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

(转)python的nltk中文使用和学习资料汇总帮你入门提高

 
阅读更多
转自:http://blog.csdn.net/huyoo/article/details/12188573
nltk是一个Python工具包, 用来处理和自然语言处理相关的东西. 包括分词(tokenize), 词性标注(POS), 文本分类, 等等现成的工具.
1. nltk的安装
资料1.1: 黄聪:Python+NLTK自然语言处理学习(一):环境搭建  http://www.cnblogs.com/huangcong/archive/2011/08/29/2157437.html   这个图文并茂, 步骤清晰, 值得一看. 我想我没必要再重新写一遍了, 因为我当时也是按照他这样做的.

资料1.2: 把python自然语言处理的nltk_data打包到360云盘,然后共享给朋友们 http://www.cnblogs.com/ToDoToTry/archive/2013/01/18/2865941.html 这个是作者将接近300M的nltk_data上传到百度云了, 我觉得, 可以试试下载, 毕竟使用资料1中nltk自带的download()方法, 从官方网站下载所有的数据包需要很长时间.
补充: 有人说, 这个下载的链接已经失效了, 我把我用的nltk2.0的data目录里的zip文件打包传到百度云盘了, 290多M, 上传我费了好多时间, 你们可以去下载: http://pan.baidu.com/s/1hq7UUFU
资料1.3: Ubuntu上安装NLTK出现的问题与解决方法 http://www.cnblogs.com/mengshu-lbq/archive/2012/09/19/2694135.html 需要的看看吧
资料1.4: 安装nltk遇到的小问题 http://blog.upupbug.com/?p=106
资料1.5  安装nltk后导入语料的时候出错, 一般是一些依赖包没安装 http://blog.tianya.cn/blogger/post_show.asp?BlogID=762305&PostID=8954744
资料1.6 NLTK中文化處理及文字筆畫音調剖析工具整合套件 http://tm.itc.ntnu.edu.tw/CNLP/?q=node/5 台湾一个大学对nltk的介绍
资料1.7 windows下如何安装NLTK,并使用模块nltk?http://zhidao.baidu.com/question/567881533.html

2. nltk初步使用入门
资料2.1  PYTHON自然语言处理中文翻译 NLTK 中文版.pdf http://ishare.iask.sina.com.cn/f/23996193.html 中文版的《PYTHON自然语言处理》 这是一个好书,强烈推荐。这本书虽然早就有人翻译成中文了,但是还有些精力旺盛的博主还在翻译,比如这位 http://www.cnblogs.com/yuxc/archive/2011/08/29/2157415.html 《Python自然语言处理》学习笔记索引。 他翻译了很多, 中英文夹杂的,精神可嘉,做法不可取。不知道别人早就翻译完了这本书吗?

资料2.2: 黄聪:Python+NLTK自然语言处理学习(二):常用方法(similar、common_contexts、generate) http://www.cnblogs.com/huangcong/archive/2011/08/29/2158054.html 
这篇, 初步介绍了如何开始使用nltk的语料和他的一些常用方法. 有点python基础的可以直接看了.之所以放在这里, 还是因为, 只有安装好了才可以进行到这一步.

资料2.3 黄聪:Python+NLTK自然语言处理学习(三):计算机自动学习机制 http://www.cnblogs.com/huangcong/archive/2011/08/29/2158447.html 
这一篇也挺浅显易懂的.
资料2.4 python中nltk.parse_cfg是干什么用的 求例子 http://zhidao.baidu.com/question/552627368.html

3.nltk初中级应用
资料3.1: 可爱的 Python: 自然语言工具包入门 http://www.ibm.com/developerworks/cn/linux/l-cpnltk/
这个是ibm的砖家写的资料, 但是这个不能作为入门资料, 可以归结到初级应用资料. 对于那些动手能力弱的人, 这个文章真的不是那么好懂的, 所以不适合入门看, 而适合那些喜欢写代码, 喜欢鼓捣折腾的人看.

资料3.2 词性标注 http://blog.csdn.net/fxjtoday/article/details/5841453 这篇文章介绍了默认的词性标注类(比如, 所有的词都标注为名词), 基于规则标注词性, 基于正则表达式标注词性, n-gram标注词性等等.

资料3.3: Classify Text With NLTK http://blog.csdn.net/fxjtoday/article/details/5862041 别看标题是英文的, 实际上内容是中英文混合的, 不过这个比上面一篇简单些. 主要就是使用nltk对一些姓名 性别进行训练, 并预测测试语料中的姓名是啥性别. 这篇文章能够让你对 分类, 样本特征稍微有个初步入门.

资料3.4 使用nltk从非结构化数据中抽取信息 http://blog.csdn.net/fxjtoday/article/details/5871386  这篇主要介绍了命名实体识别

4.使用nltk来处理中文资料
nltk 怎么样使用中文?这是个大问题。这么个工具目前只能比较好的处理英文和其他的一些拉丁语系,谁让别人的单词与单词之间有个空格隔开呢!中文汉字一个挨一个的,nltk在分词这一关就过不去了,分词没法分,剩下的就都做不了。唯一能做的, 就是对网上现有的中文语料进行处理,这些语料都分好了词,可以使用nltk进行类似与英文的处理。

python处理中文首先需要设置一下文本的编码, 文件的首行加上: #coding utf-8 这个是给python解释器识别的,然后文件保存的时候,还需要保存为utf-8的编码。
这些编码设置完了, ntlk还是处理不了中文。

nltk处理中文的第一步障碍就是中文资料不是分好词的, 词语与词语之间没有空格。要使用nltk对中文进行处理, 首先的第一步就是中文分词(台湾叫中文断词)。

目前python中文分词的包,我推荐使用结巴分词。 使用结巴分词,之后,就可以对输出文本使用nltk进行相关处理。

当然中文分词, 不应该成为使用nltk的障碍,或许很多人认为,既然用nltk,那么nltk就应该支持中文。但是我们得认清现实,现实就是nltk就是不支持处理中文,因此,这个给国内很多自然语言处理的研究人员有了研究的空间了,nltk既然没做中文分词,那么中国人就应该自己做了这个。一个口碑比较好的中文分词工具就是ICTCLAS中文分词。

当然,我个人觉得中国人自己开发的纯python实现的结巴分词也不错。

总的来说,nltk不提供中文分词,不应该纠结于此,并止步不前,我们完全可以使用其他的中文分词工具,将需要处理的资料分好词,然后再使用nltk进行处理,因此,这里就不多说中文分词的那点事了。如果你因为中文分词而分心,并转向到中文分词的研究之中,那么你就掉入了另外一个深坑之中。牢记本文的主题是nltk。当然需要多啰嗦一点的就是,nltk的默认词性标注集使用的是Penn Treebank 的词性标注集,因此,你选用中文分词模块的时候,最好能够使用和penn词性标注集差不多的中文分词工具,当然,不一样也没事。

资料4.1 使用python结巴分词对中文资料进行分词 https://github.com/fxsjy/jieba 结巴分词的github主页
资料4.2 基于python的中文分词的实现及应用 http://www.cnblogs.com/appler/archive/2012/02/02/2335834.html
资料4.3  对Python中文分词模块结巴分词算法过程的理解和分析 http://ddtcms.com/blog/archive/2013/2/4/69/jieba-fenci-suanfa-lijie/
资料4.4 宾州中文树库标记以及其解释, Penn Chinese Treebank Tag Set http://blog.csdn.net/neutblue/article/details/7375085

5.nltk的高级应用入门
啥叫高级啊? 就是基础掌握了之后,开始运用实际工作了,就叫高级。比如什么统计推荐,评分,机器翻译,文本分类,舆情监控等等都是高级应用。
下面是些入门资料。
资料1: 通过nltk的机器学习方法实现论坛垃圾帖的过滤 http://blog.sina.com.cn/s/blog_630c58cb0100vkw3.html
资料2:利用nltk建立一个简单的词库 http://blog.sina.com.cn/s/blog_630c58cb0100vkix.html
资料3:利用概率分布进行关联规则挖掘 http://blog.sina.com.cn/s/blog_630c58cb0100vll0.html

6. nltk的精通
何谓精通? 精通就是熟练的表达你的想法。
何谓精通一个工具? 就是你想做什么, 你就能用这个工具顺利的完成。do everything you want with nltk.

至于如何精通,建议多看英文资料和多动手操练。nltk官方文档, 一些参与nltk的大学研究机构,北大,清华的语言研究以及国际语言研究机构acl所发的论文等等。

假设你目前真的熟练的掌握了nltk的各种玩法了,那么, 你精通的标志就是改造nltk, 使它功能更强,更优,更快,更方便。
比如:
6.1 集成结巴分词到nltk的分词器之中
6.2 在国内多弄几个地方,放置nltk_data数据包,方便大家下载
6.3 给nltk提供语料
等等,剩下的由你来补充。

分享到:
评论

相关推荐

    python nltk 人类语言分析库 文档

    ### Python NLTK 人类语言分析库 #### 一、简介 NLTK(Natural Language Toolkit)是一个流行的Python库,专门用于处理人类语言数据。它提供了一系列简单易用的接口,能够帮助用户快速上手自然语言处理任务。NLTK...

    面向服务机器人,基于python NLTK实现自然语言处理example

    服务机器人 python NLTK 自然语言处理 example 将语音识别后的指令进行语义剖析 :构建上下文无关语法,匹配语法树,语法树遍历,打印行为序列 example:“find a person from the bedroom and ask him a question”...

    Python NLTK 数据

    在Python的世界里,自然语言处理(NLP)是一个极其重要的领域,而NLTK(Natural Language Toolkit)则是Python中最广泛使用的NLP库之一。它为研究人员和开发人员提供了丰富的工具和资源,用于处理、分析和理解人类...

    python和nltk自然语言处理源代码.zip

    此代码为Python与NLTK自然语言处理的源码。分为三个模块,第一个模块为介绍文本挖掘/NLP任务中所需要的所有预处理步骤...模块二讲述如何使用Python3的NLTK3进行文本处理;模块3讨论了如何通过Python掌握自然语言处理。

    PYTHON自然语言处理 NLTK 中文版

    ### PYTHON自然语言处理 NLTK 中文版 #### 知识点概述 1. **自然语言处理(NLP)基础知识** - 自然语言处理的基本概念 - NLP的应用场景及重要性 - NLP的基本流程:从数据预处理到模型训练与评估 2. **Python与...

    Python使用NLTK.docx

    Python使用NLTK

    PYTHON自然语言处理中文翻译 NLTK 中文版.pdf

    ### PYTHON自然语言处理中文翻译 NLTK 中文版 #### 知识点概览 1. **自然语言处理(NLP)基础知识** - 自然语言处理的定义与应用领域 - NLP的关键任务和技术 - NLP的发展历程与现状 2. **Python在自然语言处理...

    Python-rakenltkPython实现使用NLTK的快速自动关键字提取算法

    在自然语言处理(NLP)领域,关键词提取是一项重要的任务,它可以帮助我们快速理解文本的主要内容,例如用于...学习和理解这个库的源代码将有助于深入理解关键词提取的算法流程,并且能够提高你在 NLP 领域的编程能力。

    python自然语言处理(nltk 中文)

    python自然语言处理中文版, nltk的使用。

    windows环境下搭建python+nltk开发环境

    以下是一个详细的步骤指南,帮助你成功安装并开始使用Python和Nltk。 首先,你需要安装Python。在提供的文件列表中,可以看到`python-2.7.5.msi`,这表明我们将使用Python 2.7版本。双击此MSI文件,按照安装向导的...

    基于python的NLTK

    NLTK is a leading platform for building Python programs to work with human language data. It provides easy-to-use interfaces to over 50 corpora and lexical resources such as WordNet, along with a ...

    基于深度学习的自动文本分类Python NLTK设计源码

    本项目是一款基于深度学习的自动文本分类系统,采用Python语言编写,并包含16个Python源代码文件、8个Shell脚本、5个C语言文件以及若干辅助文件,共计37个文件。该系统旨在通过深度学习技术实现文本的自动分类,适用...

    PYTHON自然语言处理中文翻译+NLTK+中文版.pdf

    《PYTHON自然语言处理中文翻译+NLTK+中文版.pdf》这本书深入浅出地介绍了Python在自然语言处理(NLP)领域的应用,同时结合了NLTK(Natural Language Toolkit)这一强大的库,为读者提供了丰富的实践案例和理论知识...

    PYTHON自然语言处理中文翻译 NLTK 中文版文字版

    综上所述,这份文档是关于Python自然语言处理技术的入门和深入教程,使用NLTK库作为实现自然语言处理的一个主要工具,针对中文用户进行了翻译和本地化,以帮助中文读者更好地理解和应用这项技术。文档强调了学习自然...

    natural language processing with python最新版本 python3,NLTK3

    《自然语言处理 with Python》是Python领域中关于自然语言处理(NLP)的经典教程,针对的是Python 3和NLTK 3的最新版本。NLTK(Natural Language Toolkit)是Python中一个广泛使用的库,用于处理人类语言数据。本...

    PYTHON自然语言处理中文翻译 NLTK 中文版

    PYTHON自然语言处理中文翻译 NLTK 中文版

    Python自然语言处理 NLTK 库用法入门教程【经典】

    在学习和使用NLTK时,开发者可以探索其提供的各种资源,如语料库、分类器、模型等,这些都有助于理解自然语言处理的基本原理和实际应用。同时,NLTK的社区活跃,不断更新和改进,确保了其在NLP领域的领先地位。 总...

    python NLTK识别字符串中的人名等,命名实体识别-附件资源

    python NLTK识别字符串中的人名等,命名实体识别-附件资源

Global site tag (gtag.js) - Google Analytics