第1章教你使用內置的NLTK語料庫和頻率分布。我們還將學習什么是WordNet,并探索其特點和用法。
第2章演示如何從各種格式的數(shù)據(jù)源中提取文本。我們還將學習如何從網(wǎng)絡源提取原始文本。*后,我們將從這些異構數(shù)據(jù)源中對原始文本進行規(guī)范并構建語料庫。
第3章介紹一些關鍵的預處理步驟,如分詞、詞干提取、詞形還原和編輯距離。
第4章介紹正則表達式,它是*基本、*簡單、*重要和*強大的工具之一。在本章中,你將學習模式匹配的概念,它是文本分析的一種方式,基于此概念,沒有比正則表達式更方便的工具了。
第5章將學習如何使用和編寫自己的詞性標注器和文法規(guī)則。詞性標注是進一步句法分析的基礎,而通過使用詞性標記和組塊標記可以產生或改進文法規(guī)則。
第6章幫助你了解如何使用內置分塊器以及訓練或編寫自己的分塊器,即依存句法分析器。在本章中,你將學習評估自己訓練的模型。
第7章介紹信息抽取和文本分類,告訴你關于命名實體識別的更多信息。我們將使用內置的命名實體識別工具,并使用字典創(chuàng)建自己的命名實體。我們將學會使用內置的文本分類算法和一些簡單的應用實例。
第8章介紹高階自然語言處理方法,該方法將目前為止你所學的所有課程結合到一起,并創(chuàng)建應對你現(xiàn)實生活中各種問題的適用方法。我們將介紹諸如文本相似度、摘要、情感分析、回指消解等任務。
第9章介紹深度學習應用于自然語言處理所必需的各種基本原理,例如利用卷積神經(jīng)網(wǎng)絡(CNN)和長短型記憶網(wǎng)絡(LSTM)進行郵件分類、情感分類等,*后在低維空間中可視化高維詞匯。
第10章描述如何利用深度學習解決*前沿的問題,包括文本自動生成、情景數(shù)據(jù)問答,預測下一個*詞的語言模型以及生成式聊天機器人的開發(fā)。
譯者序
當?shù)谝淮伍喿x本書的時候,我深感它就是目前尋求自然語言處理和深度學習入門及進階方法的讀者所需要的。
眼下自然語言處理在人工智能世界大放異彩,渴望徜徉其中的讀者眾多。我在自然語言處理方面有研究基礎,此前也翻譯過一些該領域的前沿文章,希望這份譯本能幫助想通過Python工具深入鉆研自然語言處理的讀者。
本書是利用Python語言解決自然語言處理多種任務的應用指南,旨在幫助讀者快速瀏覽自然語言處理的全貌,進而掌握自然語言處理各項任務的基本原理,最終快速踏入實踐階段。Python編程語言以其清晰簡潔的語法、易用性和可擴展性以及豐富龐大的庫深受廣大開發(fā)者的喜愛。Python內置了非常強大的機器學習代碼庫和數(shù)學庫,使它理所當然地成為自然語言處理的開發(fā)利器。而其中的NLTK是使用Python處理自然語言數(shù)據(jù)的領先平臺。它為各種語言資源(比如WordNet)提供了簡便易用的界面,它還能用于高效完成文本預處理、詞性標注、信息抽取和文本分類等多種自然語言處理任務。
值得一提的是,本書特別涵蓋了自然語言處理的高階任務,比如主題識別、指代消解和創(chuàng)建聊天機器人等。本書最后兩章介紹了深度學習在自然語言處理中的應用。每一節(jié)都大致包含三個部分:準備工作、如何實現(xiàn)和工作原理,對自然語言處理各種任務的方方面面都有所涉及。這意味著,如果讀者能夠踏實地完成本書中給出的所有實例,就能切實掌握自然語言處理各種任務的基礎技術和原理方法,為進一步學習和研究奠定基礎。換言之,深入閱讀本書,對讀者探索深度學習技術在自然語言處理中的應用會有極大幫助。
最后,感謝機械工業(yè)出版社華章公司的編輯,是他們的鼓勵和支持使得本書中文版能夠與讀者見面。感謝武文雅和李興亞等多位研究生的輔助和校對,感謝我的家人的支持。盡管我們努力準確地表達出作者介紹的思想和方法,但仍難免有不當之處。若發(fā)現(xiàn)譯文中的錯誤,敬請指出,我們將非常感激,請將相關意見發(fā)往chenyf@bjtu.edu.cn。
陳鈺楓
2018年11月
親愛的讀者,感謝你選擇本書來開啟你的自然語言處理(Natural Language Processing, NLP)之路。本書將從實用的角度帶領你由淺入深逐步理解并實現(xiàn)NLP解決方案。我們將從訪問內置數(shù)據(jù)源和創(chuàng)建自己的數(shù)據(jù)源開始指引你踏上這段旅程。之后你將可以編寫復雜的NLP解決方案,包括文本規(guī)范化、預處理、詞性標注、句法分析等。
在本書中,我們將介紹在自然語言處理中應用深度學習所必需的各種基本原理,它們是目前最先進的技術。我們將使用Keras軟件來討論深度學習的應用。
本書的出發(fā)點如下:
內容設計上旨在通過細節(jié)分析來幫助新手迅速掌握基本原理。并且,對有經(jīng)驗的專業(yè)人員來說,它將更新各種概念,以便更清晰地應用算法來選擇數(shù)據(jù)。
介紹了在NLP中深度學習應用的新趨勢。
本書的組織結構
第1章教你使用內置的NLTK語料庫和頻率分布。我們還將學習什么是WordNet,并探索其特點和用法。
第2章演示如何從各種格式的數(shù)據(jù)源中提取文本。我們還將學習如何從網(wǎng)絡源提取原始文本。最后,我們將從這些異構數(shù)據(jù)源中對原始文本進行規(guī)范并構建語料庫。
第3章介紹一些關鍵的預處理步驟,如分詞、詞干提取、詞形還原和編輯距離。
第4章介紹正則表達式,它是最基本、最簡單、最重要和最強大的工具之一。在本章中,你將學習模式匹配的概念,它是文本分析的一種方式,基于此概念,沒有比正則表達式更方便的工具了。
第5章將學習如何使用和編寫自己的詞性標注器和文法規(guī)則。詞性標注是進一步句法分析的基礎,而通過使用詞性標記和組塊標記可以產生或改進文法規(guī)則。
第6章幫助你了解如何使用內置分塊器以及訓練或編寫自己的分塊器,即依存句法分析器。在本章中,你將學習評估自己訓練的模型。
第7章介紹信息抽取和文本分類,告訴你關于命名實體識別的更多信息。我們將使用內置的命名實體識別工具,并使用字典創(chuàng)建自己的命名實體。我們將學會使用內置的文本分類算法和一些簡單的應用實例。
第8章介紹高階自然語言處理方法,該方法將目前為止你所學的所有課程結合到一起,并創(chuàng)建應對你現(xiàn)實生活中各種問題的適用方法。我們將介紹諸如文本相似度、摘要、情感分析、回指消解等任務。
第9章介紹深度學習應用于自然語言處理所必需的各種基本原理,例如利用卷積神經(jīng)網(wǎng)絡(CNN)和長短型記憶網(wǎng)絡(LSTM)進行郵件分類、情感分類等,最后在低維空間中可視化高維詞匯。
第10章描述如何利用深度學習解決最前沿的問題,包括文本自動生成、情景數(shù)據(jù)問答,預測下一個最優(yōu)詞的語言模型以及生成式聊天機器人的開發(fā)。
本書需要你做什么
為了成功完成本書的實例,你需要在Windows或Unix操作系統(tǒng)上安裝Python
3.x及以上版本,硬件要求:CPU
2.0GHz以上,內存4GB以上。就Python開發(fā)的IDE而言,市場上有許多可用的IDE,但我最喜歡的是PyCharm社區(qū)版。它是一款由JetBrains開發(fā)的免費開源工具,它的技術支持很強大,會定期發(fā)布該工具的升級和修正版本,你只要熟悉IntelliJ就能保持學習進度順暢。
本書假設你已經(jīng)了解Keras的基本知識和如何安裝庫。我們并不要求讀者已經(jīng)具備深度學習的知識和數(shù)學知識,比如線性代數(shù)等。
在本書中,我們使用了以下版本的軟件,它們在最新的版本下都能很好地運行:
Anaconda 3 4.3.1 (Anaconda 中包括所有Python及相關包, Python 3.6.1, NumPy
1.12.1, pandas 0.19.2)
Theano 0.9.0
Keras 2.0.2
feedparser 5.2.1
bs4 4.6.0
gensim 3.0.1
本書的讀者對象
本書適用于想利用NLP提升現(xiàn)有技能來實現(xiàn)高階文本分析的數(shù)據(jù)科學家、數(shù)據(jù)分析師和數(shù)據(jù)科學專業(yè)人員,建議讀者具備自然語言處理的一些基本知識。
本書也適用于對自然語言處理知識毫無了解的新手,或是希望將自己的知識從傳統(tǒng)的NLP技術擴展到最先進的深度學習應用技術的有經(jīng)驗的專業(yè)人士。
小節(jié)
在本書中,有幾個標題經(jīng)常出現(xiàn)(準備工作、如何實現(xiàn)、工作原理、更多、參見)。為了明確說明如何完成一個實例,本書使用了如下內容排布:
準備工作
本節(jié)介紹完成實例的預期結果,并說明如何安裝所需的軟件或初步設置。
如何實現(xiàn)
本節(jié)包含完成實例所需遵循的步驟。
工作原理
本節(jié)通常對上一節(jié)的操作進行詳細的解釋。
更多
本節(jié)包含實例的補充信息,以便讀者對實例的實現(xiàn)方法有更多的了解。
參見
本節(jié)為實例的其他有用信息提供有效的鏈接。
約定
在本書中,你會發(fā)現(xiàn)許多不同類型信息的文本格式。下面是這些格式的一些范例和它們的含義解釋。
讀者反饋
歡迎讀者的反饋。讓我們知道你對本書的看法,哪些部分喜歡還是不喜歡。讀者反饋對我們來說很重要,因為它有助于我們了解讀者真正能從中獲益最多的地方。將你的反饋發(fā)送到郵箱feedback@packtpub.com即可,并且在你的郵箱標題中提到本書的書名。如果你有一個擅長或是比較感興趣的話題,可以撰寫或投稿書刊,請在www.packtpub.com/authors網(wǎng)站上查看作者指南。
客戶支持
既然你是一本Packt書的擁有者,在購買時能夠獲得很多額外的資源。
示例代碼下載
你可以從http://www.packtpub.com通過個人賬號下載本書的示例代碼文件。如果你在別處購買了本書,可以訪問http://
www. packtpub.com/support并進行注冊,就可以直接通過郵件方式獲得相關文件。你可以按照以下步驟下載代碼文件:
1.使用你的電子郵件地址和密碼登錄或注冊到我們的網(wǎng)站;
2.將鼠標指針置于頂部的SUPPORT選項卡上;
3.點擊Code Downloads & Errata;
4.在Search框中輸入圖書的名稱;
5.選擇你要下載的代碼文件的相應圖書;
6.從你購買本書的下拉菜單中選擇;
7.點擊Code Download。
你也可以在Packt出版社網(wǎng)站關于本書的網(wǎng)頁上通過點擊Code Files按鈕來下載代碼文件。通過在Search框中輸入圖書的名稱來訪問該頁面。請注意,你需要登錄到你的Packt賬戶。一旦文件被下載,請確保你使用的是最新版本的工具解壓文件夾:
WinRAR/7-Zip for Windows
Zipeg/iZip/UnRarX for Mac
7-Zip/PeaZip for Linux
本書的代碼可從GitHub下載,托管在https://github.com/PacktPublishing/Natural-Language-Processing-with-Python-Cookbook上。其余代碼包可以從https://github.com/PacktPublishing/上豐富的圖書和視頻目錄中獲取。請檢驗測試!
譯者序
前言
作者簡介
審校者簡介
第1章 語料庫和WordNet 1
1.1 引言
1
1.2 訪問內置語料庫 1
1.3 下載外部語料庫,加載并訪問 3
1.4 計算布朗語料庫中三種不同類別的特殊疑問詞 5
1.5 探討網(wǎng)絡文本和聊天文本的詞頻分布 7
1.6 使用WordNet進行詞義消歧 9
1.7 選擇兩個不同的同義詞集,使用WordNet探討上位詞和下位詞的概念 12
1.8 基于WordNet計算名詞、動詞、形容詞和副詞的平均多義性 15
第2章 針對原始文本,獲取源數(shù)據(jù)和規(guī)范化 17
2.1 引言
17
2.2 字符串操作的重要性 17
2.3 深入實踐字符串操作 19
2.4 在Python中讀取PDF文件 21
2.5 在Python中讀取Word文件
23
2.6 使用PDF、DOCX和純文本文件,創(chuàng)建用戶自定義的語料庫 26
2.7 讀取RSS信息源的內容 29
2.8 使用BeautifulSoup解析HTML 31
第3章 預處理 34
3.1 引言
34
3.2 分詞學習使用NLTK內置的分詞器 34
3.3 詞干提取學習使用NLTK內置的詞干提取器 36
3.4 詞形還原學習使用NLTK中的WordnetLemmatizer函數(shù)
38
3.5 停用詞學習使用停用詞語料庫及其應用 40
3.6 編輯距離編寫計算兩個字符串之間編輯距離的算法 42
3.7 處理兩篇短文并提取共有詞匯 44
第4章 正則表達式 50
4.1 引言
50
4.2 正則表達式學習使用*、 和? 50
4.3 正則表達式學習使用$和^,以及如何在單詞內部(非開頭與結尾處)進行模式匹配 52
4.4 匹配多個字符串和子字符串 54
4.5 學習創(chuàng)建日期正則表達式和一組字符集合或字符范圍 56
4.6 查找句子中所有長度為5的單詞,并進行縮寫 58
4.7 學習編寫基于正則表達式的分詞器 59
4.8 學習編寫基于正則表達式的詞干提取器 60
第5章 詞性標注和文法 63
5.1 引言
63
5.2 使用內置的詞性標注器 63
5.3 編寫你的詞性標注器 65
5.4 訓練你的詞性標注器 70
5.5 學習編寫你的文法 73
5.6 編寫基于概率的上下文無關文法 76
5.7 編寫遞歸的上下文無關文法 79
第6章 分塊、句法分析、依存分析 82
6.1 引言
82
6.2 使用內置的分塊器 82
6.3 編寫你的簡單分塊器 84
6.4 訓練分塊器 87
6.5 遞歸下降句法分析 90
6.6 shift-reduce句法分析
93
6.7 依存句法分析和主觀依存分析 95
6.8 線圖句法分析 97
第7章 信息抽取和文本分類 101
7.1 引言
101
7.2 使用內置的命名實體識別工具 102
7.3 創(chuàng)建字典、逆序字典和使用字典 104
7.4 特征集合選擇 109
7.5 利用分類器分割句子 113
7.6 文本分類 116
7.7 利用上下文進行詞性標注 120
第8章 高階自然語言處理實踐 124
8.1 引言
124
8.2 創(chuàng)建一條自然語言處理管道 124
8.3 解決文本相似度問題 131
8.4 主題識別 136
8.5 文本摘要 140
8.6 指代消解 143
8.7 詞義消歧 147
8.8 情感分析 150
8.9 高階情感分析 153
8.10 創(chuàng)建一個對話助手或聊天機器人 157
第9章 深度學習在自然語言處理中的應用 163
9.1 引言
163
9.2 利用深度神經(jīng)網(wǎng)絡對電子郵件進行分類 168
9.3 使用一維卷積網(wǎng)絡進行IMDB情感分類
175
9.4 基于雙向LSTM的IMDB情感分類模型 179
9.5 利用詞向量實現(xiàn)高維詞在二維空間的可視化 183
第10章 深度學習在自然語言處理中的高級應用 188
10.1 引言
188
10.2 基于莎士比亞的著作使用LSTM技術自動生成文本 188
10.3 基于記憶網(wǎng)絡的情景數(shù)據(jù)問答 193
10.4 使用循環(huán)神經(jīng)網(wǎng)絡LSTM進行語言建模以預測最優(yōu)詞 199
10.5 使用循環(huán)神經(jīng)網(wǎng)絡LSTM構建生成式聊天機器人 203