2016-11-29 299 views
4
# -*- coding: utf-8 -*- 

''' 
한국어 형태 분석된 자료를 word2Vec모델로 만드는 모듈 
입력은 형태분석된 파일을 취함 
한 줄에 한 문장씩 
출력으로 model을 형성 
''' 

import codecs 
import gensim 
import multiprocessing 
import word2vec 

import sys 
reload(sys) 
sys.setdefaultencoding('utf8') 

# 모델 configuration 설정 
config = { 
    'min_count': 15, # 등장 횟수가 15 이하인 단어는 무시 
    'size': 300, # 300차원짜리 벡터스페이스에 embedding 
    'sg': 1, # 0이면 CBOW, 1이면 skip-gram 
    'batch_words': 10000, # 사전을 구축할때 한번에 읽을 단어 수 
    'iter': 10, # 보통 딥러닝에서 말하는 epoch과 비슷한, 반복 횟수 
    'workers': multiprocessing.cpu_count(), 
} 

modelTwitterNoStop = gensim.models.Word2Vec(**config) 

class SentenceReader: 

    def __init__(self, filepath): 
     self.filepath = filepath 


    def __iter__(self): 
     for line in codecs.open(self.filepath, encoding='utf-8'): 
      yield line.split(' ') 

# 사전과 학습을 형태분석된 파일을 가지고 행함 
sentences_vocab = SentenceReader('corpusAllNewsNoTagNoStop.txt') 
sentences_train = SentenceReader('corpusAllNewsNoTagNoStop.txt') 

#model = gensim.models.Word2Vec() 
modelTwitterNoStop.build_vocab(sentences_vocab) 
modelTwitterNoStop.train(sentences_train) 

#이렇게 학습된 모델을 저장 
modelTwitterNoStop.save('modelTwitterNoStop') 


### 모델 테스트 ########## 
#다음 라인부터는 분리하여 별도로 Test모델 프로그램을 만들어 다양한 관계를 실험해 볼 수 있음 

import codecs 
import gensim 
import multiprocessing 

import sys 
reload(sys) 
sys.setdefaultencoding('utf8') 

##도 포함 


#만들어 놓은 gensim 모델을 로딩 
modelTwitterNoStop = gensim.models.Word2Vec.load('modelTwitterNoStop') 


#most similar Test - 상위 10개의 유사한 벡터를 찾음.. 실제로 '일본'이 가장 높은 것으로 나 
print ' '.join(["{}-{}".format(word, value) for word, value in 
(modelTwitterNoStop.most_similar(positive=[u"한국", u"도쿄"], negative=[u"서 울"], topn=10))]) 

print "\n" 

# positive만 사용해서도 할 수 있으며 cosmul을 이용 
print ' '.join(["{}-{}".format(word, value) for word, value in 
(modelTwitterNoStop.most_similar_cosmul(positive=[u"비선", u"최순실"], topn=20))]) 
print "\n" 

#doesn't match Test 
print modelTwitterNoStop.doesnt_match(u"정윤회 김종 박근혜 최순실".split()) 

print "\n" 

#similarity Test 
print modelTwitterNoStop.similarity(u"비선", u"정윤회") 
print "\n" 

# no.of vocab.. in this model 
print modelTwitterNoStop 
print "\n" 

警告(從警告模塊): 文件 「C:\ Python27 \ LIB \站點包\ gensim \ utils.py」,線路840 warnings.warn(「視窗檢測;混淆chunkize to chunkize_serial「) UserWarning:檢測到的Windows; aliasing chunkize to chunkize_serial問題安裝

+0

請添加[mcve](http://stackoverflow.com/help/mcve)示例來了解安裝和使用情況。 –

+0

[安裝gensim時發生Chunkize警告]的可能重複(http://stackoverflow.com/questions/41658568/chunkize-warning-while-installing-gensim) –

回答

0

這不是問題。僅用於Windows,它的處理方式不同。 如果你不想看到這條消息,你可以使用this的代碼回答

0

這只是一個警告,不是錯誤。每當我導入gensim時,我也會在windows上獲得它。我不認爲安裝有問題。