forked from FerreroJeremy/ln2sql
-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathThesaurus.py
executable file
·42 lines (33 loc) · 1.35 KB
/
Thesaurus.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# -*- coding: utf-8 -*
import sys
reload(sys)
sys.setdefaultencoding("utf-8")
import unicodedata
class Thesaurus:
def __init__(self):
self.dictionnary = {}
def add_entry(self, word, synonyms):
self.dictionnary[word] = synonyms
def add_synonym_of_a_word(self, word, synonym):
self.dictionnary[word].append(synonym)
def get_synonyms_of_a_word(self, word):
if word in self.dictionnary.keys():
return self.dictionnary[word]
def remove_accents(self, string):
nkfd_form = unicodedata.normalize('NFKD', unicode(string))
return u"".join([c for c in nkfd_form if not unicodedata.combining(c)])
def load(self, path):
with open(path) as f:
content = f.readlines()
# we jump content[0] because it is the encoding-type line : useless to parse
for line_id in range(1,len(content)):
if '(' not in content[line_id]:
line = content[line_id].split("|")
word = self.remove_accents(line[0])
synonyms = self.remove_accents(content[line_id + 1]).split("|")
synonyms.pop(0)
self.add_entry(word, synonyms)
def print_me(self):
for keys,values in self.dictionnary.items():
print(keys)
print(values)