[bugfix] WIP, creating new issue: Could not save project after initializing Event table; PySide2.QTableWidgetItem cannot be pickled!

This commit is contained in:
Marcel Paffrath 2021-07-09 15:31:12 +02:00
parent de11c3b611
commit aa73bb0ae8
2 changed files with 37 additions and 33 deletions

View File

@ -29,6 +29,7 @@ import os
import platform import platform
import shutil import shutil
import sys import sys
import copy
import traceback import traceback
@ -3192,24 +3193,24 @@ class MainWindow(QMainWindow):
# changes attributes of the corresponding event # changes attributes of the corresponding event
table = self.project._table table = self.project._table
event = self.project.getEventFromPath(table[row][1].text().split('*')[0]) event = self.project.getEventFromPath(table[row][1].text().split('*')[0])
if column == 9 or column == 10: if column == 10 or column == 11:
# toggle checked states (exclusive) # toggle checked states (exclusive)
item_ref = table[row][9] item_ref = table[row][10]
item_test = table[row][10] item_test = table[row][11]
if column == 9 and item_ref.checkState(): if column == 10 and item_ref.checkState():
item_test.setCheckState(QtCore.Qt.Unchecked) item_test.setCheckState(QtCore.Qt.Unchecked)
event.setRefEvent(True) event.setRefEvent(True)
elif column == 9 and not item_ref.checkState(): elif column == 10 and not item_ref.checkState():
event.setRefEvent(False) event.setRefEvent(False)
elif column == 10 and item_test.checkState(): elif column == 11 and item_test.checkState():
item_ref.setCheckState(QtCore.Qt.Unchecked) item_ref.setCheckState(QtCore.Qt.Unchecked)
event.setTestEvent(True) event.setTestEvent(True)
elif column == 10 and not item_test.checkState(): elif column == 11 and not item_test.checkState():
event.setTestEvent(False) event.setTestEvent(False)
self.fill_eventbox() self.fill_eventbox()
elif column == 11: elif column == 12:
# update event notes # update event notes
notes = table[row][11].text() notes = table[row][12].text()
event.addNotes(notes) event.addNotes(notes)
self.fill_eventbox() self.fill_eventbox()
@ -3230,7 +3231,7 @@ class MainWindow(QMainWindow):
# init new qtable # init new qtable
self.event_table = QTableWidget(self) self.event_table = QTableWidget(self)
self.event_table.setColumnCount(12) self.event_table.setColumnCount(len(self.table_headers))
self.event_table.setRowCount(len(eventlist)) self.event_table.setRowCount(len(eventlist))
self.event_table.setHorizontalHeaderLabels(self.table_headers) self.event_table.setHorizontalHeaderLabels(self.table_headers)
@ -3318,7 +3319,7 @@ class MainWindow(QMainWindow):
item_test.setCheckState(QtCore.Qt.Unchecked) item_test.setCheckState(QtCore.Qt.Unchecked)
row = [item_delete, item_path, item_time, item_lat, item_lon, item_depth, item_localmag, row = [item_delete, item_path, item_time, item_lat, item_lon, item_depth, item_localmag,
item_momentmag, item_nmp, item_nap, item_ref, item_test, item_notes] item_momentmag, item_nmp, item_nap, item_ref, item_test, item_notes]
self.project._table.append(row) self.project._table.append(row)
self.setItemColor(row, index, event, current_event) self.setItemColor(row, index, event, current_event)
@ -3375,20 +3376,20 @@ class MainWindow(QMainWindow):
def exportProjectTable(self, filename, separator=';'): def exportProjectTable(self, filename, separator=';'):
with open(filename, 'w') as outfile: with open(filename, 'w') as outfile:
for header in self.table_headers[1:12]: for header in self.table_headers[1:13]:
outfile.write('{}{}'.format(header, separator)) outfile.write('{}{}'.format(header, separator))
outfile.write('\n') outfile.write('\n')
for row in self.project._table: for row in self.project._table:
row = row[1:12] row = row[1:13]
event, time, lat, lon, depth, mag, nmp, nap, tune, test, notes = row event, time, lat, lon, depth, ml, mw, nmp, nap, tune, test, notes = row
row_str = '' row_str = ''
for index in range(len(row)): for index in range(len(row)):
row_str += '{}'+'{}'.format(separator) row_str += '{}'+'{}'.format(separator)
row_str = row_str.format(event.text(), time.text(), lat.text(), lon.text(), depth.text(), mag.text(), row_str = row_str.format(event.text(), time.text(), lat.text(), lon.text(), depth.text(), ml.text(),
nmp.text(), nap.text(), bool(tune.checkState()), bool(test.checkState()), mw.text(), nmp.text(), nap.text(), bool(tune.checkState()),
notes.text()) bool(test.checkState()), notes.text())
outfile.write(row_str + '\n') outfile.write(row_str + '\n')
message = 'Wrote table to file: {}'.format(filename) message = 'Wrote table to file: {}'.format(filename)
@ -3628,7 +3629,7 @@ class MainWindow(QMainWindow):
autosaveXML = get_Bool(settings.value('autosaveXML', True)) autosaveXML = get_Bool(settings.value('autosaveXML', True))
if autosaveXML: if autosaveXML:
self.exportEvents() self.exportEvents()
self.project.save(filename) if not self.project.save(filename): return False
self.setDirty(False) self.setDirty(False)
self.saveProjectAsAction.setEnabled(True) self.saveProjectAsAction.setEnabled(True)
self.update_status('Saved new project to {}'.format(filename), duration=5000) self.update_status('Saved new project to {}'.format(filename), duration=5000)
@ -3652,7 +3653,7 @@ class MainWindow(QMainWindow):
autosaveXML = get_Bool(settings.value('autosaveXML', True)) autosaveXML = get_Bool(settings.value('autosaveXML', True))
if autosaveXML: if autosaveXML:
self.exportEvents() self.exportEvents()
self.project.save() if not self.project.save(): return False
self.update_obspy_dmt() self.update_obspy_dmt()
if not self.project.dirty: if not self.project.dirty:
self.setDirty(False) self.setDirty(False)
@ -3879,34 +3880,37 @@ class Project(object):
Can be loaded by using project.load(filename). Can be loaded by using project.load(filename).
''' '''
try: try:
import cPickle import pickle
except ImportError: except ImportError:
import _pickle as cPickle import _pickle as pickle
if filename: if filename:
self.location = filename self.location = filename
else: else:
filename = self.location filename = self.location
table = self._table # MP: see below
try: try:
outfile = open(filename, 'wb') outfile = open(filename, 'wb')
cPickle.dump(self, outfile, -1) self._table = [] # MP: Workaround as long as table cannot be saved as part of project
pickle.dump(self, outfile, protocol=pickle.HIGHEST_PROTOCOL)
self.setDirty(False) self.setDirty(False)
self._table = table # MP: see above
return True
except Exception as e: except Exception as e:
print('Could not pickle PyLoT project. Reason: {}'.format(e)) print('Could not pickle PyLoT project. Reason: {}'.format(e))
self.setDirty() self.setDirty()
self._table = table # MP: see above
return False
@staticmethod @staticmethod
def load(filename): def load(filename):
''' '''
Load project from filename. Load project from filename.
''' '''
try: import pickle
import cPickle
except ImportError:
import pickle as cPickle
infile = open(filename, 'rb') infile = open(filename, 'rb')
project = cPickle.load(infile) project = pickle.load(infile)
infile.close() infile.close()
project.location = filename project.location = filename
print('Loaded %s' % filename) print('Loaded %s' % filename)

View File

@ -296,13 +296,13 @@ class Event(ObsPyEvent):
:rtype: None :rtype: None
""" """
try: try:
import cPickle import pickle
except ImportError: except ImportError:
import _pickle as cPickle import _pickle as pickle
try: try:
outfile = open(filename, 'wb') outfile = open(filename, 'wb')
cPickle.dump(self, outfile, -1) pickle.dump(self, outfile, -1)
self.dirty = False self.dirty = False
except Exception as e: except Exception as e:
print('Could not pickle PyLoT event. Reason: {}'.format(e)) print('Could not pickle PyLoT event. Reason: {}'.format(e))
@ -317,11 +317,11 @@ class Event(ObsPyEvent):
:rtype: Event :rtype: Event
""" """
try: try:
import cPickle import pickle
except ImportError: except ImportError:
import _pickle as cPickle import _pickle as pickle
infile = open(filename, 'rb') infile = open(filename, 'rb')
event = cPickle.load(infile) event = pickle.load(infile)
event.dirty = False event.dirty = False
print('Loaded %s' % filename) print('Loaded %s' % filename)
return event return event