【Python自然语言处理】第一章学习笔记——搜索文本、计数统计和字符串链表
这本书主要是基于Python和一个自然语言工具包(Natural Language Toolkit, NLTK)的开源库进行讲解
NLTK
- 介绍:NLTK是一个构建Python程序以处理人类语言数据的平台,它为50多个语料库和词汇资源(如WordNet)提供了易于使用的接口,以及一套用于分类、标记、解析和语义推理等的文本处理库。
- 配置:在安装Python和Anaconda之后直接
import nltk
本文是使用jupyter notebook进行编译。
函数:
搜索文本
- 搜索单个词出现的地方:A_text.concordance("A_word")
- 搜索跟一个词出现在相似上下文的所有词:A_text.similar("A_word")
- 搜索两个词出现的相同上下文,也就是分别先找到这两个词的上下文,然后取交集:A_text.common_contexts{["word1", "word2"]}
- 用离散图表示一个词在文本中出现的位置,横坐标为从文本开头算起的词数目,也就是一个词在文本中出现的位置,每一行为一个文本,纵坐标为要搜索的单词(可以是多个,用逗号隔开):A_text.dispersion_plot(["w1", "w2", "w3"]
生成文本:根据一篇文本生成相似风格的新文本。A_text.generate() 这个功能已经被注释掉,不能使用,就先当不存在吧。。。
计数统计
- 统计文本长度即单词和标点数目:len(A_text)
- 统计文本中有多少个不同的单词和标点:先将文本转化为集合得到一个词汇表,由于集合中的元素都不是不重复的,所以可以通过统计集合大小来获取:len(set(A_text)
- 可以用sorted函数来有序输出词汇表中的词汇:sorted(set(A_text)
- 统计每个单词平均被使用的次数,即文本词汇丰富度:len(A_text)/len(set(A_text)
- 统计一个单词在一个文本中的出现次数:A_text.count("A_word")
文本:
将文本表示为词链表:sent1=['Call', 'me', 'Ishmael', '.']
- 链表的加法为头尾连接两个链表:sent1+sent2; 乘法是复制自己并拼接在一起:sent1*2
- 在链表中追加一个元素:sent1.append(""A_word")
- 链表的连接:'X'.join(['Monty', 'Python']), X是任意连接符
- 链表的分隔:sent1.split(‘X’)
链表索引,即下标,从0开始
- 通过下标定位到某个词:text4[173]
- 找出一个词第一次出现时的索引,即下标:text4.index('awaken')
- 不取第16735个数。
- 第一个数字省略时表示从头开始取起,第二个省略则表示一直取到末尾
- 两个值可以都是负数,因为链表是个循环链表,但是起点正值的时候不能超过链表长度,终点可以。
- 可以用新内容替换一个片段,新内容长度可小于、等于、大于片段长度
切片,即从大文本中抽取一个片段,得到一个子链表:text5[16715:16735]。注:
简单文本统计:
获取文本中每个词的频次,以键值对的形式存储:FreqDist(A_text)
- 获取FreqDist中的key值,以list存储:list(FreqDist(A_text).keys())
- 获取FreqDist中的键值对,以dict_items字典存储:FreqDist(A_text).items()
- 获取FreqDist中频次为1的key的列表,以list存储:FreqDist(A_text).hapaxes()
- 取某个key的频次:FreqDist(A_text)[A_key]。如果是字符,要加引号
- 取频次最大的key值:FreqDist(A_text).max()
- 取某个key值的频率:FreqDist(A_text).freq(A_key)
- 取样本总数:FreqDist(A_text).N()
- 绘制频次分布表:FreqDist(A_text).tabulate()
- 绘制频次分布图:FreqDist(A_text).plot()
- 绘制累积频率分布图:FreqDist(A_text).plot(cumulative=True)
- 测试样本在fdist1中出现的概率是否小于fdist2
寻找长词且高频词
-
寻找常见词语搭配和双连词:
- 枚举所有双连词:list(bigrams(A_text))
- 寻找最常见的双连词:A_text.collocations()

- 比较两字符
- s.startswith(t)
- s.endswith(t)
- t in s
- s.islower():测试s中所有字符是否都是小写字母
- s.issupper():大写
- s.isalpha():测试s中所有字符是否都是字母
- s.isalnum():是否都是字母或数字
- s.isdigit():是否都是数字
- s.istitile():s中所有词是否都首字母大写
【Python自然语言处理】第一章学习笔记——搜索文本、计数统计和字符串链表的更多相关文章
- 《Think Python》第17章学习笔记
目录 <Think Python>第17章学习笔记 17.1 面向对象的特性(Object-oriented features) 17.2 打印对象(Printing objects) 1 ...
- 《Think Python》第16章学习笔记
目录 <Think Python>第16章学习笔记 16.1 Time 16.2 纯函数(Pure functions) 16.3 修改器(Modifiers) 16.4 原型 vs. 方 ...
- 《Think Python》第15章学习笔记
目录 <Think Python>第15章学习笔记 15.1 程序员定义的类型(Programmer-defined types) 15.2 属性(Attributes) 15.3 矩形( ...
- Spring实战第一章学习笔记
Spring实战第一章学习笔记 Java开发的简化 为了降低Java开发的复杂性,Spring采取了以下四种策略: 基于POJO的轻量级和最小侵入性编程: 通过依赖注入和面向接口实现松耦合: 基于切面 ...
- Day1 《机器学习》第一章学习笔记
<机器学习>这本书算是很好的一本了解机器学习知识的一本入门书籍吧,是南京大学周志华老师所著的鸿篇大作,很早就听闻周老师大名了,算是国内机器学习领域少数的大牛了吧,刚好研究生做这个方向相关的 ...
- [蛙蛙推荐]SICP第一章学习笔记-编程入门
本书简介 <计算机程序的构造与解释>这本书是MIT计算机科学学科的入门课程, 大部分学生在学这门课程前都没有接触过程序设计,也就是说这本书是针对编程新手写的. 虽然是入门课程,但起点比较高 ...
- 《Think Python》第8章学习笔记
目录 8.1 字符串是一个序列(A string is a sequence) 8.2 len 8.3 用一个 for 循环进行遍历(Traversal with a for loop) 8.4 字符 ...
- 《Django By Example》第一章 学习笔记
首先看了下目录,在这章里 将会学到 安装Django并创建你的第一个项目 设计模型(models)并且生成模型(model)数据库迁移 给你的模型(models)创建一个管理站点 使用查询集(Quer ...
- 《Java基础教程》第一章学习笔记
Java 是什么呀! 计算机语言总的来说分成机器语言,汇编语言,高级语言.其中Java一种高级计算机语言,它是一种可以编写跨平台应用软件,完全面向对象的程序设计语言. Java划分为三个技术平台,Ja ...
随机推荐
- c++ 222
[成功者的习惯] 1.背后说别人好话:听到某人说别人坏话时只微笑: 2.过去的事不全让人知道: 3. 尊敬不喜欢你的人:对事无情,对人有情: 4.多做自我批评:为别人喝彩: 5.感恩:学会 ...
- 给小程序组件创建slot
<!--comviewonents/juan/juan.wxml--> <view class="model-wrapper" hidden="{{vi ...
- pyspider的基本操作
一.安装 pip install pyspider 1.修改 pyspider/webui/webdav.py 第209行:否则启动会报错 把: 'domaincontroller': NeedAut ...
- docker 启动容器报错
2018-10-24 报错信息: /usr/bin/docker-current: Error response from daemon: driver failed programming exte ...
- web安全漏洞种类
(参考知道创宇) SQL注入: SQL注入(SQL Injection),是一个常见的发生于应用程序和数据库之间的web安全漏洞,由于在开发过程中的设计不当导致程序中忽略了检查,没有有效的过滤用户的输 ...
- kali 安装命令类
apt-get常用命令:update – 取回更新的软件包列表信息upgrade – 进行一次升级install – 安装新的软件包(注:软件包名称是 libc6 而非 libc6.deb)remov ...
- java I/O流 温习随笔
java I/O流的熟练掌握是十分重要的. 在我的理解中,I/O流可以分为两种:字符流.字节流.字符流就是可以用来传输字符的流,比如传输txt文本,简单的说,只有能被电脑中的记事本直接打开并且你能看懂 ...
- Javascript模块化编程详解
在这篇文章中,我将会回顾一下js模块化编程的基础,并且将会讲到一些真的非常值得一提的进阶话题,包括一个我认为是我自创的模式. 模块化编程是一种非常常见Javascript编程模式.它一般来说可以使得代 ...
- 6、图标:icon
1.图标 /* ---html----*/ <ion-content text-center class="icons-basic-page"> <ion-row ...
- 用DebuggerDisplay在Visual Studio的调试器中定制类的显示方式
博客搬到了fresky.github.io - Dawei XU,请各位看官挪步.最新的一篇是:用DebuggerDisplay在Visual Studio的调试器中定制类的显示方式.
