HanLP-停用詞表的使用示例
停用詞表的修改
停用詞表在 “pyhanlp\static\data\dictionary”路徑下的“stopwords.txt”檔案中,CoreStopWordDictionary.apply方法支援去除停用詞。如果需要修改停用詞表,則直接編輯檔案“stopwords.txt”,之後刪除路徑下的“stopwords.txt.bin”,執行CoreStopWordDictionary.apply後即可自動生效。有關驗證的方法見“驗證是否生效”小節。
自定義詞語過濾方法
使用者可以透過編寫 “pyhanlp\static”路徑下的“MyFilter.java”檔案設定自己的詞語過濾方法。應當注意這裡處理的語言單位是詞語,而不是字。編輯完畢後需要編譯該檔案並生成位元組碼檔案,之後執行CoreStopWordDictionary.apply方法時就會自動呼叫使用者自己的詞語過濾方法了。這裡給出一個自定義過濾方法的編寫示例程式碼。
import os
from pyhanlp.static import STATIC_ROOT, HANLP_JAR_PATH
java_code_path = os.path.join(STATIC_ROOT, 'MyFilter.java')
with open(java_code_path, 'w') as out:
java_code = """
import com.hankcs.hanlp.dictionary.stopword.CoreStopWordDictionary;
import com.hankcs.hanlp.dictionary.stopword.Filter;
import com.hankcs.hanlp.seg.common.Term;
public class MyFilter implements Filter
{
public boolean shouldInclude(Term term)
{
if (term.nature.startsWith('m')) return false; // 數詞過濾
if (term.nature.startsWith('q')) return false; // 量詞過濾
if (term.nature.startsWith('t')) return false; // 時間詞過濾
if (term.nature.startsWith("w")) return false; // 過濾標點符號
return !CoreStopWordDictionary.contains(term.word); // 停用詞過濾
}
}
"""
out.write(java_code)
os.system('javac -cp {} {} -d {}'.format(HANLP_JAR_PATH, java_code_path, STATIC_ROOT))
驗證是否生效
本節給出停用詞表修改後以及使用了自定義詞語過濾方法的示例程式碼。
from pyhanlp import *
# 載入停用詞類
CoreStopWordDictionary = JClass("com.hankcs.hanlp.dictionary.stopword.CoreStopWordDictionary")
# 載入自定義詞語過濾邏輯
MyFilter = JClass('MyFilter')
CoreStopWordDictionary.FILTER = MyFilter()
term_list = HanLP.segment(text)
CoreStopWordDictionary.apply(term_list)
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31524777/viewspace-2645141/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 最全中文停用詞表整理(1893個)
- HanLP-實詞分詞器詳解HanLP分詞
- pyhanlp 停用詞與使用者自定義詞典功能詳解HanLP
- python使用jieba實現中文文件分詞和去停用詞PythonJieba分詞
- 如何在java中去除中文文字的停用詞Java
- Spark中分散式使用HanLP(1.7.0)分詞示例Spark分散式HanLP分詞
- ES 實現實時從Mysql資料庫中讀取熱詞,停用詞MySql資料庫
- 完整的牛津3000詞彙表及牛津5000詞彙表
- 基於JavaScript的關鍵詞過濾示例JavaScript
- hanlp 載入遠端詞庫示例HanLP
- Android 圖表開源庫調研及使用示例Android
- SharePoint詞彙表
- oralce 跨使用者訪問表 同義詞
- AntDesignBlazor示例——Modal表單Blazor
- 使用Broker管理Data Guard——停用、改保護模式等模式
- win10 停用 dedender方法 win10 怎麼停用defenderWin10
- xrender中的FormRender使用示例ORM
- HanLP-地名識別除錯方法HanLP地名識別除錯
- ACL 2019 | Few-shot Learning學習詞表外的詞表示
- JMeter使用示例JMeter
- Tcpdump使用示例TCP
- GPUImageRawDataInput 使用示例GPUUIAI
- rsync 使用示例
- 為什麼停用CentOS?CentOS
- HanLP-命名實體識別總結HanLP
- Vue中async await的使用示例VueAI
- Java使用ObjectMapper的簡單示例JavaObjectAPP
- Python模組 adorner 的使用示例Python
- MySQL join連表查詢示例MySql
- 蘋果手機已停用解鎖辦法 iPhone已停用怎麼辦?蘋果iPhone
- 自動為新建的表建立同義詞
- Hanlp-地名識別除錯方法詳解HanLP地名識別除錯
- 使用Spring Boot實現的GraphQL示例Spring Boot
- Flutter使用MVVM設計模式的示例FlutterMVVM設計模式
- Nuxt Kit 實用工具的使用示例UX
- 例2.9 字典的get()方法使用示例
- Mysql中常用函式的使用示例MySql函式
- PHP 中,pack 與 unpack 的使用示例。PHP