[bugfix] picksdict was corrupted so that no manual picks could be loaded from .xml, fixes #20

This commit is contained in:
Marcel Paffrath 2021-08-10 17:40:49 +02:00
parent e850e5d4fe
commit 2dd48b4c62
3 changed files with 25 additions and 24 deletions

View File

@ -2895,11 +2895,7 @@ class MainWindow(QMainWindow):
event.pylot_autopicks = {} event.pylot_autopicks = {}
picksdict = picksdict_from_picks(evt=self.get_data().get_evt_data()) picksdict = picksdict_from_picks(evt=self.get_data().get_evt_data())
event.addPicks(picksdict['manual']) event.addPicks(picksdict['manual'])
if picksdict['auto'] == {}: event.addAutopicks(picksdict['auto'])
event.addAutopicks(picksdict)
else:
event.addAutopicks(picksdict['auto'])
def drawPicks(self, station=None, picktype=None, stime=None): def drawPicks(self, station=None, picktype=None, stime=None):
# if picktype not specified, draw both # if picktype not specified, draw both

View File

@ -167,9 +167,8 @@ class Data(object):
def checkEvent(self, event, fcheck, forceOverwrite=False): def checkEvent(self, event, fcheck, forceOverwrite=False):
""" """
Check information in supplied event and own event and replace own Check information in supplied event and own event and replace with own
information with supplied information if own information not exiisting information if no other information are given or forced by forceOverwrite
or forced by forceOverwrite
:param event: Event that supplies information for comparison :param event: Event that supplies information for comparison
:type event: pylot.core.util.event.Event :type event: pylot.core.util.event.Event
:param fcheck: check and delete existing information :param fcheck: check and delete existing information
@ -225,7 +224,7 @@ class Data(object):
def replacePicks(self, event, picktype): def replacePicks(self, event, picktype):
""" """
Replace own picks with the one in event Replace picks in event with own picks
:param event: Event that supplies information for comparison :param event: Event that supplies information for comparison
:type event: pylot.core.util.event.Event :type event: pylot.core.util.event.Event
:param picktype: 'auto' or 'manual' picks :param picktype: 'auto' or 'manual' picks
@ -233,20 +232,23 @@ class Data(object):
:return: :return:
:rtype: None :rtype: None
""" """
checkflag = 0 checkflag = 1
picks = event.picks picks = event.picks
# remove existing picks # remove existing picks
for j, pick in reversed(list(enumerate(picks))): for j, pick in reversed(list(enumerate(picks))):
try: try:
if picktype in str(pick.method_id.id): if picktype in str(pick.method_id.id):
picks.pop(j) picks.pop(j)
checkflag = 1 checkflag = 2
except AttributeError as e: except AttributeError as e:
msg = '{}'.format(e) msg = '{}'.format(e)
print(e) print(e)
checkflag = 0 checkflag = 0
if checkflag: if checkflag > 0:
print("Found %s pick(s), remove them and append new picks to catalog." % picktype) if checkflag == 1:
print("Write new %s picks to catalog." % picktype)
if checkflag == 2:
print("Found %s pick(s), remove them and append new picks to catalog." % picktype)
# append new picks # append new picks
for pick in self.get_evt_data().picks: for pick in self.get_evt_data().picks:
@ -274,8 +276,11 @@ class Data(object):
raise FormatError(errmsg) raise FormatError(errmsg)
if hasattr(self.get_evt_data(), 'notes'): if hasattr(self.get_evt_data(), 'notes'):
with open(os.path.join(os.path.dirname(fnout), 'notes.txt'), 'w') as notes_file: try:
notes_file.write(self.get_evt_data().notes) with open(os.path.join(os.path.dirname(fnout), 'notes.txt'), 'w') as notes_file:
notes_file.write(self.get_evt_data().notes)
except Exception as e:
print('Warning: Could not save notes.txt: ', str(e))
# check for already existing xml-file # check for already existing xml-file
if fnext == '.xml': if fnext == '.xml':
@ -532,7 +537,7 @@ class Data(object):
def setEvtData(self, event): def setEvtData(self, event):
self.evtdata = event self.evtdata = event
def applyEVTData(self, data, typ='pick', authority_id='rub'): def applyEVTData(self, data, typ='pick'):
""" """
Either takes an `obspy.core.event.Event` object and applies all new Either takes an `obspy.core.event.Event` object and applies all new
information on the event to the actual data if typ is 'event or information on the event to the actual data if typ is 'event or

View File

@ -244,13 +244,13 @@ def picksdict_from_picks(evt):
else: else:
filter_id = None filter_id = None
try: try:
picker = str(pick.method_id) pick_method = str(pick.method_id)
if picker.startswith('smi:local/'): if pick_method.startswith('smi:local/'):
picker = picker.split('smi:local/')[1] pick_method = pick_method.split('smi:local/')[1]
except IndexError: except IndexError:
picker = 'manual' # MP MP TODO maybe improve statement pick_method = 'manual' # MP MP TODO maybe improve statement
if picker == 'None': if pick_method == 'None':
picker = 'manual' pick_method = 'manual'
try: try:
#onsets = picksdict[picker][station] #onsets = picksdict[picker][station]
onsets = picksdict[station] onsets = picksdict[station]
@ -289,7 +289,7 @@ def picksdict_from_picks(evt):
phase['weight'] = weight phase['weight'] = weight
phase['channel'] = channel phase['channel'] = channel
phase['network'] = network phase['network'] = network
phase['picker'] = picker phase['picker'] = pick_method
try: try:
if pick.polarity == 'positive': if pick.polarity == 'positive':
phase['fm'] = 'U' phase['fm'] = 'U'
@ -303,7 +303,7 @@ def picksdict_from_picks(evt):
phase['filter_id'] = filter_id if filter_id is not None else '' phase['filter_id'] = filter_id if filter_id is not None else ''
onsets[pick.phase_hint] = phase.copy() onsets[pick.phase_hint] = phase.copy()
picksdict[station] = onsets.copy() picksdict[pick_method][station] = onsets.copy()
return picksdict return picksdict