Fix Find Duplicate Persons to find all combinations

This commit is contained in:
prculley 2020-01-15 16:10:56 -06:00
parent 30241dd8b0
commit d99cbb160c

View File

@ -96,8 +96,6 @@ class DuplicatePeopleTool(tool.Tool, ManagedWindow):
self.dbstate = dbstate self.dbstate = dbstate
self.uistate = uistate self.uistate = uistate
self.map = {} self.map = {}
self.list = []
self.index = 0
self.merger = None self.merger = None
self.mergee = None self.mergee = None
self.removed = {} self.removed = {}
@ -181,7 +179,7 @@ class DuplicatePeopleTool(tool.Tool, ManagedWindow):
else: else:
try: try:
DuplicatePeopleToolMatches(self.dbstate, self.uistate, DuplicatePeopleToolMatches(self.dbstate, self.uistate,
self.track, self.list, self.map, self.track, self.map,
self.update) self.update)
except WindowActiveError: except WindowActiveError:
pass pass
@ -191,7 +189,6 @@ class DuplicatePeopleTool(tool.Tool, ManagedWindow):
_('Looking for duplicate people'), _('Looking for duplicate people'),
parent=self.window) parent=self.window)
index = 0
males = {} males = {}
females = {} females = {}
self.map = {} self.map = {}
@ -229,28 +226,19 @@ class DuplicatePeopleTool(tool.Tool, ManagedWindow):
else: else:
remaining = females[key] remaining = females[key]
#index = 0
for p2key in remaining: for p2key in remaining:
#index += 1
if p1key == p2key: if p1key == p2key:
continue continue
p2 = self.db.get_person_from_handle(p2key) tup = (p1key, p2key) if p1key < p2key else (p2key, p1key)
if p2key in self.map: if tup in self.map:
(v,c) = self.map[p2key] # already found that pair
if v == p1key:
continue continue
p2 = self.db.get_person_from_handle(p2key)
chance = self.compare_people(p1, p2) chance = self.compare_people(p1, p2)
if chance >= thresh: if chance >= thresh:
if p1key in self.map: self.map[tup] = chance
val = self.map[p1key]
if val[1] > chance:
self.map[p1key] = (p2key,chance)
else:
self.map[p1key] = (p2key,chance)
self.list = sorted(self.map)
self.length = len(self.list)
self.progress.close() self.progress.close()
def gen_key(self, val): def gen_key(self, val):
@ -539,13 +527,11 @@ class DuplicatePeopleTool(tool.Tool, ManagedWindow):
class DuplicatePeopleToolMatches(ManagedWindow): class DuplicatePeopleToolMatches(ManagedWindow):
def __init__(self, dbstate, uistate, track, the_list, the_map, callback): def __init__(self, dbstate, uistate, track, the_map, callback):
ManagedWindow.__init__(self, uistate, track, self.__class__) ManagedWindow.__init__(self, uistate, track, self.__class__)
self.dellist = set() self.dellist = set()
self.list = the_list
self.map = the_map self.map = the_map
self.length = len(self.list)
self.update = callback self.update = callback
self.db = dbstate.db self.db = dbstate.db
self.dbstate = dbstate self.dbstate = dbstate
@ -586,31 +572,23 @@ class DuplicatePeopleToolMatches(ManagedWindow):
def on_help_clicked(self, _obj): def on_help_clicked(self, _obj):
"""Display the relevant portion of Gramps manual""" """Display the relevant portion of Gramps manual"""
display_help(WIKI_HELP_PAGE , WIKI_HELP_SEC) display_help(WIKI_HELP_PAGE , WIKI_HELP_SEC)
def redraw(self):
list = []
for p1key, p1data in self.map.items():
if p1key in self.dellist:
continue
(p2key,c) = p1data
if p2key in self.dellist:
continue
if p1key == p2key:
continue
list.append((c,p1key,p2key))
def redraw(self):
self.list.clear() self.list.clear()
for (c,p1key,p2key) in list: for tup, chance in self.map.items():
c1 = "%5.2f" % c if tup[0] in self.dellist:
c2 = "%5.2f" % (100-c)
p1 = self.db.get_person_from_handle(p1key)
p2 = self.db.get_person_from_handle(p2key)
if not p1 or not p2:
continue continue
if tup[1] in self.dellist:
continue
c1 = "%5.2f" % chance
c2 = "%5.2f" % (100 - chance)
p1 = self.db.get_person_from_handle(tup[0])
p2 = self.db.get_person_from_handle(tup[1])
pn1 = name_displayer.display(p1) pn1 = name_displayer.display(p1)
pn2 = name_displayer.display(p2) pn2 = name_displayer.display(p2)
self.list.add([c1, pn1, pn2,c2],(p1key,p2key)) self.list.add([c1, pn1, pn2, c2], tup)
def on_do_merge_clicked(self, _obj): def on_do_merge_clicked(self, _obj):
_store, iter_ = self.list.selection.get_selected() _store, iter_ = self.list.selection.get_selected()