| import json | |
| import os | |
| import time | |
| import logging | |
| import re | |
| from api.utils.file_utils import get_project_base_directory | |
| class Dealer: | |
| def __init__(self, redis=None): | |
| self.lookup_num = 100000000 | |
| self.load_tm = time.time() - 1000000 | |
| self.dictionary = None | |
| path = os.path.join(get_project_base_directory(), "rag/res", "synonym.json") | |
| try: | |
| self.dictionary = json.load(open(path, 'r')) | |
| except Exception as e: | |
| logging.warn("Miss synonym.json") | |
| self.dictionary = {} | |
| if not redis: | |
| logging.warning( | |
| "Realtime synonym is disabled, since no redis connection.") | |
| if not len(self.dictionary.keys()): | |
| logging.warning(f"Fail to load synonym") | |
| self.redis = redis | |
| self.load() | |
| def load(self): | |
| if not self.redis: | |
| return | |
| if self.lookup_num < 100: | |
| return | |
| tm = time.time() | |
| if tm - self.load_tm < 3600: | |
| return | |
| self.load_tm = time.time() | |
| self.lookup_num = 0 | |
| d = self.redis.get("kevin_synonyms") | |
| if not d: | |
| return | |
| try: | |
| d = json.loads(d) | |
| self.dictionary = d | |
| except Exception as e: | |
| logging.error("Fail to load synonym!" + str(e)) | |
| def lookup(self, tk): | |
| self.lookup_num += 1 | |
| self.load() | |
| res = self.dictionary.get(re.sub(r"[ \t]+", " ", tk.lower()), []) | |
| if isinstance(res, str): | |
| res = [res] | |
| return res | |
| if __name__ == '__main__': | |
| dl = Dealer() | |
| print(dl.dictionary) | |