【语言处理与Python】2.1获取文本语料库

古藤堡语料库(电子文本档案经过挑选的一小部分文本)

#语料库中所有的文件

Import nltk

Nltk.corpus.gutenberg.fileids()

 

From nltk.corpus import Gutenberg

Gutenberg.fileids()

Emma=Gutenberg.words(‘austen-emma.txt’)

 

 

#挑选其中的某一部著作进行操作

Emma=nltk.corpus.gutenberg.words(‘austen-emma.txt’)

Num_chars=len(Gutenberg.raw(fileid))

Num_words=len(Gutenberg.words(fileid))

Num_sents=len(Gutenberg.sents(fileid))

Num_vocab=len(set([w.lower() for w in Gutenberg.words(fileid)]))

 

 

网络和聊天文本

From nltk.corpus import webtext

From nltk.corpus import nps_chat

 

 

布朗语料库

 

#对布朗语料库的一些操作:

From nltk.corpus import brown

Brown.categories()#语料库的一些分类

Brown.words(categories=’news’)#访问某一文体的单词

Brown.words(fields=[‘cg22’])

Brown.sents(categories=[‘news’,’editorial’,’reviews’])

#使用条件频率分布做一些统计

Cfd=nltk.ConditionalFreqdist(

(genre,word)

For genre in brown.categories()

For word in brown.words(categories=genre)

)

Genres=[‘news’,’religion’,’hobbies’,’science_fiction’,’’romance’,’humor’]

Modals=[‘can’,’could’,’may’,’might’,’must’m’will’]

Cfd.tabulate(conditions=generes,samples=modals)

 

 

路透社语料库(新闻文档,分成了90个主题,按照训练和测试分为两组)

就职演说语料库

#使用条件分布做一些统计工作

Cfd=nltk.ConditionalFreqdist(

(target,fileid[:4])

For fileid in inaugural.fileids()

For w in inaugural.words(fileid)

For target in [‘america’,’citizen’]

If  w.lower().startswith(target)

)

Cfd.plot()

 

 

标注文本语料库(含有语言学标注,词性标注、命名实体、句法结构、语义角色等)

在其他语言的语料库

文本语料库的结构

 

 

载入自己的语料库

#在一些地方可以用匹配符号

From nltk.corpus import PlaintextCorpusReader

Corpus_root=’/usr/share/dict’

Wordlists=PlaintextCorpusReader(corpus_root,’.*’)

Wordlists.fileids()

Wordlists.words(‘connectives’)

#在硬盘上的语料库

From nltk.corpus import BracketParseCorpusReader

Corpus_root=r”C:\corpura\penntreebank\parsed\mrg\wsj”

File_pattern=r”.*/wsj_.*\.mrg”

Ptb=BracketParseCorpusReader(corpus_root,file_pattern)

Ptb.fileids()

 

posted @ 2013-05-22 12:27  createMoMo  阅读(2530)  评论(0编辑  收藏  举报