Sistema de Apoio ao Processo Legislativo
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

52 lines
1.5 KiB

from sapl.comissoes.models import Comissao, Composicao, Reuniao
from sapl.materia.models import DespachoInicial, Relatoria, UnidadeTramitacao
from difflib import SequenceMatcher
models_dependentes = [Composicao, DespachoInicial, Relatoria, UnidadeTramitacao, Reuniao]
def similar(a, b):
return SequenceMatcher(None, a, b).ratio()
def detecta_duplicados():
lst_duplicados = []
comissoes = Comissao.objects.all().order_by('id')
for c_1 in comissoes:
c_1_lst = []
for c_2 in comissoes:
if similar(c_1.nome,c_2.nome) > 0.9 and c_1.id != c_2.id:
c_1_lst.append(c_2)
comissoes = comissoes.exclude(id=c_2.id)
if c_1_lst:
c_1_lst.append(c_1)
comissoes = comissoes.exclude(id=c_1.id)
lst_duplicados.append(c_1_lst)
return lst_duplicados
def muda_autor(principal, secundaria):
for autor in secundaria.autor.all():
autor.delete()
def muda_models_dependentes(principal,secundaria):
for model in models_dependentes:
for obj in model.objects.filter(comissao=secundaria):
obj.comissao = principal
obj.save()
def junta_dulpicados(duplicados):
principal = duplicados[-1]
for secundaria in duplicados[:-1]:
muda_models_dependentes(principal,secundaria)
muda_autor(principal, secundaria)
secundaria.delete()
def main():
lst_duplicados = detecta_duplicados()
for c in lst_duplicados:
junta_dulpicados(c)
if __name__ == '__main__':
main()