Python – GKIPtagger – 國產斷詞工具
文章推薦指數: 80 %
該機構過去也有開發一個舊版本的斷詞工具,不過在這版本之前,該組織都沒有 ... 著實驗的精神來嘗試,如有成果將會分享一篇精準抓取中文文章關鍵字。
跳至主要內容
發佈日期:2020-12-312021-01-08作者:EW 分類:Python標籤:關鍵字-中文版
簡介
在網路海中找尋有關關鍵字提取的技術時,赫然發現了一個跟Jieba相同的斷詞工具,是由我們國家機構中研院所開發的一個開源工具,叫做GKIPtagger。
該機構過去也有開發一個舊版本的斷詞工具,不過在這版本之前,該組織都沒有公開分享過他們研究的成果,只有線上demo版本。
而舊的版本效果跟Jieba差不多,下圖是他們所做的實驗準確率比較表,看來是比Jieba的準確率高了七趴,所以這篇想來試試看它的威力與實作部分。
官方文件
GKIPtagger特色
這套工具算是近期才發布的開源套件,而中研院的CKIPLabdemo網站中有蠻多案例,可以去裡面看看。
在使用該工具之前,我們可以先看看他有哪一些獨特的點,引用他們網站的敘述如下:
結合實體辨識目標是在文字資料當中,能夠辨識出感興趣的專有名詞(包含原本資料庫不存在的新專有名詞),並自動標記正確的分類。
目前CkipTagger能辨識11類一般領域專有名詞及7類數量詞,包含:人名、團體、設施、組織、地理、地點、商品、事件、藝術品、法律、語言、日期、時間、比例、錢、數量、序數、數詞
支援使用者自訂參考/強制詞典從實際應用的角度,能夠支援使用者自訂詞典是一個相當重要的功能。
一般而言,以字為標記單元的機器學習/深度學習的斷詞模型通常因為算法本身的特性,而難以提供使用者自訂詞典的功能。
CkipTagger則克服了這個限制,雖是使用以字為標記單元的模型,但仍然支援使用者自訂詞典,包含參考詞典與強制詞典,且每個詞彙均可指定權重,讓使用者能根據自身的任務需求與領域,自行進行系統的客製化
支援不限長度的句子不會自動增/刪/改輸入的文字
實操
Step1安裝:
該套件提供三個版本讓我們去選擇安裝,分別是以下三種以及TF。
//在安裝下面套件之前請先在你的condaenv安裝tensorflow,版本介於1.13-2.0
//標準-我選擇這個安裝
pipinstall-Uckiptagger[tf,gdown]
//簡易
pipinstall-Uckiptagger
//完整
pipinstall-Uckiptagger[tfgpu,gdown]
Step2下載模型:
由於該套件在做每一個斷詞的工序時會去讀取他們訓練好的NLP模型檔案,所以必須要將模型檔案下載在本地資料夾中。
下載連結,我這邊是透過jupyternotebook做實驗,而下載下來解壓縮後會是個名為data資料夾,放置位置如上圖所示。
雖然下載模型的方法也可以套過『gdown』套件來下載,但我覺得這樣太慢了,直接下載放在資料夾比較快。
Step3讀取模型檔:
fromckiptaggerimportWS,POS,NER
#TouseGPU:
#1.Installtensorflow-gpu(seeInstallation)
#2.SetCUDA_VISIBLE_DEVICESenvironmentvariable,e.g.os.environ["CUDA_VISIBLE_DEVICES"]="0"
#3.Setdisable_cuda=False,e.g.ws=WS("./data",disable_cuda=False)
#TouseCPU:
ws=WS("./data")
pos=POS("./data")
ner=NER("./data")
接著我們要讀取上一步驟下載來的模型檔案,透過CKIPtagger套件的函式,所以要先import近來,並將這幾個函式引數放進路徑。
該方法是使用CPU的方式來撰寫。
上方有隱藏起來GPU使用方法。
上圖是我片面了解的該套件這三個主要函式的工作流程,WS(斷詞)->POS(詞性標記)->NER(命名實體),這流程可能才是產出最佳斷詞的結果,而其中的一些元素可能還要再深入了解一下。
Step4放入測試文句與權重設定(選用):
上圖是測試詞句的兩種模式,第一個是官方拿來演繹的資料型態,是使用list,而其實透過字串的資料型態也是可以使用,只是後續的程式寫法也會有所不同。
上圖是在進入主程式之前,可以設定該文章中假如有出現這些文字的話,會讓他提取分數提高,而這區塊是選用的。
另外一個選用的程式碼是釋放記憶體,上圖是撰寫方式。
Step5處理區塊:
這邊整理了兩種資料型態的引數處理區塊程式碼寫法,在Step3中有提到,以下是官方提供的list資料型態寫法:
//處理階段
word_sentence_list=ws(
sentence_list,
#sentence_segmentation=True,#Toconsiderdelimiters
#segment_delimiter_set={",","。
",":","?","!",";"}),#Thisisthedefualtsetofdelimiters
#recommend_dictionary=dictionary1,#wordsinthisdictionaryareencouraged
#coerce_dictionary=dictionary2,#wordsinthisdictionaryareforced
)
pos_sentence_list=pos(word_sentence_list)
entity_sentence_list=ner(word_sentence_list,pos_sentence_list)
//實現階段
defprint_word_pos_sentence(word_sentence,pos_sentence):
assertlen(word_sentence)==len(pos_sentence)
forword,posinzip(word_sentence,pos_sentence):
print(f"{word}({pos})",end="\u3000")
print()
return
fori,sentenceinenumerate(sentence_list):
print()
print(f"'{sentence}'")
print_word_pos_sentence(word_sentence_list[i],pos_sentence_list[i])
forentityinsorted(entity_sentence_list[i]):
print(entity)
下方則是字串資料型態引數的寫法:
//執行階段
ws_results=ws([text])
pos_results=pos(ws_results)
ner_results=ner(ws_results,pos_results)
//實現階段
print(ws_results)
print(pos_results)
fornameinner_results[0]:
print(name)
Step6成果:
List資料型態
String資料型態
可以看到提取的結果有些微的差距,大家都可以選用這兩種不同的引數與實現方法。
小結
透過實操後,我們知道了要怎要使用這開源工具,在後續我想透過斷詞來擷取整個文章的關鍵字提取,如此一來應該可以更準確的抓到與本文近乎相關的關鍵字吧,秉持著實驗的精神來嘗試,如有成果將會分享一篇精準抓取中文文章關鍵字。
另外也會研究一下『NLTK』其他語系的斷詞與關鍵字提取的工具研究。
發佈留言取消回覆
發佈留言必須填寫的電子郵件地址不會公開。
必填欄位標示為*留言顯示名稱*
電子郵件地址*
個人網站網址
在瀏覽器中儲存顯示名稱、電子郵件地址及個人網站網址,以供下次發佈留言時使用。
文章導覽
Github–常用指令Unreal-GettingSTART1
搜尋關鍵字:
近期文章
MochaPro利用Tracking去除LOGO
MongoDB新手學習-網路文章入門法
MetaHuman不用建模的超逼真虛擬人物
WordPressSkill–使用者登入指定頁面與顯示頁面
Python–packaginglightexefile
彙整
2021年8月 (3)
2021年4月 (1)
2021年2月 (11)
2021年1月 (30)
2020年12月 (45)
2020年11月 (47)
2020年10月 (47)
2020年9月 (55)
2020年8月 (46)
2020年6月 (1)
2020年5月 (15)
2020年2月 (2)
2020年1月 (14)
2019年12月 (42)
2019年11月 (76)
2019年10月 (75)
2019年9月 (10)
2019年4月 (1)
分類
2DMotionGraphic
3DModeling
3DMotionGraphic
Adobe
AfterEffect
AI
Blender3D
C4D
Chatbot
Database
Django
OctaneRender
Photoshop
Python
SubstancePainter
Substance系列工具
Texturing
Uncategorized
UnityHDRP
Unity3D
Unity3DPerformanceOptimization
Unity3DUI&GUI
UnrealEngine
UX/UI
VFX
VideoComposition
WebHost
XParticles
工作流程優化
平台公告
數位行銷
自駕車
延伸文章資訊
- 1Python jieba 中文斷詞套件 - 大學生's Blog
jieba中文斷詞套件. 结巴中文分词. https://github.com/fxsjy/jieba. 交大資管開發的結巴(jieba)斷詞台灣繁體特化版本.
- 2Python自然語言處理(二):使用jieba進行中文斷詞
原本打算用英文寫的,可是jieba是在斷中文,還用英文寫就有點怪XD. “Python自然語言處理(二):使用jieba進行中文斷詞” is published by Yanwei Liu.
- 3中文斷詞
目前繁體中文斷詞系統有中研院CKIP 以及jieba,在一些舊的文章中都提到jieba ... wordcloud pip3 install matplotlib yum -y install ...
- 4[Day2] 斷詞介紹 - iT 邦幫忙
[Day2] 斷詞介紹 · 安裝總之呢要先安裝套件,對python熟的人,應該都知道就是這樣安裝: · 載入繁體中文的辭典~這個的位置在Jieba的github有提供,這裡附上網址 · Jieb...
- 5[NLP][Python] 中文斷詞最方便的開源工具之一: Jieba
Jieba 是一款使用Python (或者說在Python 上最知名的?) 的一款開源中文斷詞工具,當然它也有支援許多不同的NLP 任務,比方說POS、關鍵字抽取.