TraduzSentencas.py 1.55 KB
#!/usr/bin/python
# -*- coding: utf-8 -*-

#Autor: Erickson Silva 
#Email: <erickson.silva@lavid.ufpb.br> <ericksonsilva@live.com>

#LAViD - Laboratório de Aplicações de Vídeo Digital

from threading import Thread
import alexp
from AplicaSinonimos import *
from AplicaRegras import * 
import logging

class TraduzSentencas(Thread):
	
	def __init__(self, sentenca):
		Thread.__init__(self)
		self.sentenca = sentenca
		self.glosa = ""
		self.aplic_sinonimos = AplicaSinonimos()
		self.aplic_regras = AplicaRegras()
		logging.basicConfig(filename='translate.log',
                            format='%(asctime)s - %(levelname)s:\n%(message)s\n\n\n##############################################\n\n',
                            level=logging.ERROR)


	def run(self):
		try:
			analise_sintatica = alexp.run(self.sentenca)
		except Exception as ex:
			self.salvar_log(str(ex))
			analise_sintatica = None

		analise_morfologica = alexp.getAnaliseMorfologica()

		if (isinstance(analise_sintatica,type(None))):
			print "# ANÁLISE MORFOLÓGICA"
			regras_aplicadas = self.aplic_regras.aplicar_regras_morfo(analise_morfologica)
		else:
			print "# ANÁLISE SINTÁTICA"
			regras_aplicadas = self.aplic_regras.aplicar_regras_sint(analise_morfologica, analise_sintatica)

		sentenca_corrigida = self.aplic_regras.simplificar_sentenca(regras_aplicadas)
		sinonimos_aplicados = self.aplic_sinonimos.aplicar_sinonimos(sentenca_corrigida)
		self.glosa = sinonimos_aplicados.upper().encode('utf-8')

	def obter_glosa(self):
		return self.glosa

	def salvar_log(self, erro):
		logging.error(erro)